当前位置:  数据库>oracle

Oracle中的程序包

    来源: 互联网  发布时间:2017-05-09

    本文导语: 一程序包的基本概念 程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(specification)和主体(body)。程序报也可以包含常量和变量,包中的所有函数和存储过程都可以使用这些变...

一程序包的基本概念

程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(specification)和主体(body)。程序报也可以包含常量和变量,包中的所有函数和存储过程都可以使用这些变量或者常量。

二 规范

1 创建规范(SQL窗口)

create or replace package pkg_staff as
       staffString varchar2(500);
       stafftAge number:=18;
       function get_staff_string return varchar2;
       procedure insert_staff(in_staff_id in number,in_staff_name in varchar2);
       procedure update_staff(in_staff_id in number);
       procedure delete_staff(in_staff_id in number);
end pkg_staff;







2 在数据字典中查看程序包规范的信息

select object_name,object_type,status from user_objects
where lower(OBJECT_NAME) = 'pkg_staff'

三 主体

所谓规范,就像面向对象编程中的接口,该规范的主体必须实现该规范的所有方法。Oracle会自动寻找与主体同名的规范,看是否全部实现了该规范函数或者存储过程。若没有,则编译错误。

1 创建主体

create or replace package body pkg_staff as
       function get_staff_string return varchar2 as
       begin
                return 'staff';
       end get_staff_string;
       procedure insert_staff(in_staff_id in number,in_staff_name in varchar2) as
       begin
                 insert into staff values (in_staff_id,in_staff_name);
       end insert_staff;
       procedure update_staff(in_staff_id in number) as
       begin
                 update staff set name = 'xy' where num = in_staff_id;
       end update_staff;
       procedure delete_staff(in_staff_id in number) as
       begin
                 delete from staff where num = '1';
       end delete_staff;
end pkg_staff;
















2 在数据字典中查看程序包主体的信息

select object_name,object_type,status from user_objects
where lower(OBJECT_NAME) = 'pkg_staff'

四调用程序包中的函数或者存储过程

调用函数(SQL window)
select pkg_staff.get_staff_string() as result from dual


调用存储过程(Command window)
begin
pkg_staff.delete_staff(1);
end;
/





    
 
 

您可能感兴趣的文章:

  • win2000+jbuilder6+oracle817编出的程序,在win2000下执行很好,在win98下却访问不了oracle数据库
  • 驱动程序找不到Class.forName("oracle.jdbc.driver.OracleDriver");,在程序中还要设置什么?
  • 100分寻求最优化的连接oracle的java程序,请给我讲出理由,我是初学者,在做项目时不想让连接oracle影响我的程序性能
  • 给linux oracle程序员一个交流的家
  • 请问那里可以下载oracle 9i for linux 64位的安装程序 小弟只有10分了帮帮忙拉!!
  • 请问谁有oracle8.0.5的jdbc驱动程序!!!!!
  • liunx下用c开发oracle程序
  • unix通过crontab 定时启动oracle应用程序??????????
  • 为什么在编译java程序的时候出现oracle.jdbc.driver不存在?急!!!
  • 如何将Oracle数据库驱动程序加载到classpath中?
  • 为什么 export ORACLE_SID=test写在程序里面就不会执行?
  • 请问某个数据库(如oracle)的jdbc驱动程序是不是在所有平台下通用?
  • Web服务器/前端 iis7站长之家
  • Linux/UNIX下,C++程序通过那些步骤访问Oracle或者Sybase SQL数据库?
  • 成功实现应用程序和Oracle客户端一起打包
  • jdk1.3+tomcat怎样配置oracle驱动程序
  • ubuntu系统中运行java程序调用oracle 的sqlplus,为什么找不到sqlplus呢?在线等
  • 千分放送!请有AIX下dbx调试Oracle proc程序经验的高手解决问题
  • SOS!java如何用jdbc与oracle相连,是否要安装相应的驱动程序
  • linux 环境下 odbc程序 往oracle数据库insert 中文 乱码问题,请教高手,急!!!!在线等~~
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,