PLSQL——程序包

1.程序包概述

程序包是对相关过程、函数、变量、游标和异常等对象的封装
程序包由规范(包头)和主体(包体)两部分组成
规范中可以声明程序包中公共对象。
包括类型、变量、常量、异常、游标规范和子程序规范等
主体中可以声明程序包私有对象和实现在包规范中声明的子程序和游标

2.创建程序包的语法

包头和包体名字一致
程序包规范语法

CREATE [OR REPLACE] PACKAGE 名字 IS|AS
[Public item declarations]
[Subprogram specification]
END [package_name];
create or replace package package_name is/as
Public item declaraions   --公共声明部分
Subprogram specification  --声明PL/SQL子程序
End package_namne         --包的名称

程序包主体
CREATE [OR REPLACE] PACKAGE BODY 名字 IS|AS
[Public item declarations]
[Subprogram bodies]
[BEGIN
Initialization]
END [package_name];

package_name是包的名称
public type and item declarations::私有声明部分
subprogram specificatons:子程序体

如:

--定义包头
create or replace package pack1
is
   aa number := 9;
   procedure insert_dept(v_dept in dept%rowtype);
   function fun(v1 number,v2 number) return number;
end;
--包体实现
create or replace package body pack1
is
bb number := 10;
procedure insert_dept(v_dept in dept%rowtype)
is
begin
   insert into dept values(v_dept.deptno,v_dept.dname,v_dept.loc);

end;

function fun(v1 number,v2 number) return number
is
begin
  return v1 + v2;
end;
end;

调用:包名.元素名;

3.程序包中的游标

游标的定义分为游标规范和游标主体两部分
在包规范中声明游标规范时必须使用return子句指定游标的返回类型
return 数据类型
;
RETURN子句指定的数据类型可以是:
用 %ROWTYPE 属性引用表定义的记录类型
程序员定义的记录类型,例如 TYPE EMPRECTYP IS RECORD(emp_id INTEGER,salary REAL) 来定义的。
不可以是number, varchar2, %TYPE等类型。

如:

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值