文档章节

oracle 程序包基础之基础

陈爱茹cx1992
 陈爱茹cx1992
发布于 2016/07/26 17:36
字数 505
阅读 2
收藏 0
程序包可以将若干个函数和存储过程组织起来,作为一个对象进行存储。
程序包由两部分构成:规范(specification) 和主体(body)

规范:是程序包的公共接口。类似于面向对象编程中的接口-只定义方法名称和参数,并不真正实现方法。

1.创建程序包规范(create or replace package)
  演示创建基于表students的规范
  create or replace package pkg_students as
         studentString varchar2(500);
         studentAge number :=18;
         function getStudentNameString return varchar2;
         procedure update_student(in_student_id in varchar2);
         procedure insert_student(in_student_id in varchar2,in_student_name in varchar2,
           in_student_age in number);
          procedure delete_student(in_student_id in varchar2);
   end pkg_students;
   
   说明:StudentString varchar2(500) 用于定义一个名为studentString 的可变字符串类型的变量;
   studentAge number :=18;用于定义一个名为studentAge的数值型变量,并将变量赋值为3;
   function getStudentNameString return varchar2;声明了一个函数;
   procedure update_student(in_student_id in varchar2);声明了存储过程;
     
   主体
   主体是真正实现功能的地方。主体必须实现规范中定义的函数和过程。
   1、创建程序包主体(create or replace body)
       create or replace package body pkg_students as
       ........       
       end pkg_students;
       
       具体
       
       create or replace package body pkg_students as

            function getStudentNameString return varchar2 as
              begin
                declare cursor cu_student is
                select student_name from students order by student_id;
                student_name varchar2(180);
                rowString varchar2(1000);

                begin
                  open cu_student;
                  fetch cu_student into student_name;
                  while cu_student%found loop
                    rowString :=rowString || student_name || ',';
                    fetch cu_student into student_name;
                   end loop;
                   return substr(rowString,1,length(rowString)-1);
               end;
              end getStudentNameString;


             procedure update_student(in_student_id in varchar2)  as
              begin
                update students set student_age = studentAge where student_id = in_student_id;
                commit;
              end update_student;

             procedure insert_student(in_student_id in varchar2,
               in_student_name in varchar2,
               in_student_age in number) as
               begin
                 insert into students values(
                        in_student_id,in_student_name,in_student_age
                 );
                 commit;
                end insert_student;

             procedure delete_student(in_student_id in varchar2) as
               begin
                 delete from students where student_id = in_student_id;
               commit;
               end delete_student;
         end pkg_students;

     2、调用程序包中 的函数/存储过程
     
         调用程序包中的函数
              select pkg_students.getStudentNameString() from dual;
              
         调用程序包中的存储过程
               begin pkg_students.delete_student(3);
               end;
         存储过程中使用程序包中变量
               begin pkg_students.update_student(9);
               end;
               将学生id=9的学生年龄改为18
           studentAge number :=18;在程序包规范中声明的变量 可以在主体存储过程中使用

本文转载自:http://blog.csdn.net/ruru7989/article/details/12403441

共有 人打赏支持
陈爱茹cx1992
粉丝 0
博文 59
码字总数 0
作品 0
济南
程序员
红帽Linux 6.5上配置ASM流程

ASM(Automatic Storage Management)是Oracle官方推荐的软件存储解决方案。自10g版本正式推出以来,软件架构层面上ASM的地位是在不断的提升。首先是11g将ASM从数据库层面剥离出来,并归入G...

青夜之衫
2017/12/06
0
0
福利:《系统运维管理专家》双11团购大礼包

本次活动技术涉及大型企业IT系统基础设施平台的管理与维护,技术涉及计算机基础、主机系统、数据库、网络、虚拟机、云计算、存储备份、JAVA基础、Python自动化、项目管理等技术,是大型企业《...

51CTO学院
2017/10/26
0
0
基于ADO.NET方法的数据库连接的数据发生器控件dotConnect for Oracle

dotConnect for Oracle完全基于ADO.NET方法,因此您完全可以采用标准ADO.NET数据提供的方法来使用它。是一款为Microsoft .NET Framework提供直接Oracle数据库连接的数据发生器控件。 具体功能...

netkongjian
2014/04/18
0
0
每周一书《Oracle 12 c PL(SQL)程序设计终极指南》

本周为大家送出的书是《Oracle 12 c PL(SQL)程序设计终极指南》,此书由机械工业出版社出版, 孙风栋,王澜,郭晓惠 著。 内容简介: 《Oracle 12c PL/SQL程序设计终极指南》志在打造PL/SQL领...

zting科技
2017/12/11
0
0
基于DotNet构件技术的企业级敏捷软件开发平台 - AgileEAS.NET - 程序集说明

今天放出了AgileEAS.NET的ActiveXForm和SmartWin的体验,在大家对为东西有个简单的了解和感觉后,我会选择在合适的时间发放完整的开发包。 我想有的朋友安装了客户端也很想知道,那些程序集文...

agilelab
2010/06/26
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

最全最强解析:支付宝钱包系统架构内部剖析(架构图)

支付宝系统架构概况 典型处理默认 资金处理平台 财务会计 支付清算 核算中心 交易 柔性事务 支付宝的开源分布式消息中间件–Metamorphosis(MetaQ) Metamorphosis (MetaQ) 是一个高性能、高可...

晨猫
29分钟前
4
0
竞品分析

那什么样的场景需要用关键纬度分析法分析竞品呢? 竞品分析的目的是为了看竞品们和自己产品重合的业务都具备哪些功能点,以及这些功能是怎么做的,以此确定自己产品的优化方向。 竞品们的业务...

于谦老师
37分钟前
1
0
OSChina 周三乱弹 —— 公司女同事约我

Osc乱弹歌单(2018)请戳(这里) 【今日歌曲】 @莱布妮子:分享水木年华的单曲《蝴蝶花(2002年大提琴版)》 《蝴蝶花(2002年大提琴版)》- 水木年华 手机党少年们想听歌,请使劲儿戳(这里) ...

小小编辑
今天
1K
16
Linux环境搭建 | VMware下共享文件夹的实现

在进行程序开发的过程中,我们经常要在主机与虚拟机之间传递文件,比如说,源代码位于虚拟机,而在主机下阅读或修改源代码,这里就需要使用到 「共享文件」 这个机制了。本文介绍了两种共享文...

良许Linux
今天
9
0
JUC锁框架——AQS源码分析

JUC锁介绍 Java的并发框架JUC(java.util.concurrent)中锁是最重要的一个工具。因为锁,才能实现正确的并发访问。而AbstractQueuedSynchronizer(AQS)是一个用来构建锁和同步器的框架,使用A...

长头发-dawn
今天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部