最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

Oracle中的程序包

来源:动视网 责编:小采 时间:2020-11-09 11:11:22
文档

Oracle中的程序包

Oracle中的程序包:程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(specification)和主体(body)。程 一程序包的基本概念 程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(sp
推荐度:
导读Oracle中的程序包:程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(specification)和主体(body)。程 一程序包的基本概念 程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(sp


程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(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;
/

文档

Oracle中的程序包

Oracle中的程序包:程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(specification)和主体(body)。程 一程序包的基本概念 程序包可将若干函数或者存储过程组织起来,作为一个对象进行存储。程序包通常由两部分构成,规范(sp
推荐度:
标签: 中的 数据库 oracle
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top