oracle学习笔记(二十一) 程序包
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了oracle学习笔记(二十一) 程序包,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1551字,纯文字阅读大概需要3分钟。
内容图文
程序包
之前我们调用的dbms_output.put_line('')
,dbms_output
就是一个程序包
程序包创建语法
1. 声明程序包
--声明程序包中的过程,函数,自定义的类型
--程序包里面的过程和函数不需要使用create or repalce
create or replace package dbms_my
is
record类型等。
procedure $procedure_name$ [(参数...)];
function $function_name$ [(参数...)]
......
end dbms_my;
2. 实现程序包
create or replace package body dbms_my
is
procedure <过程名>
is
......
end dbms_my;
程序包例子
--创建程序包
create or replace package dbms_my
is
--相当于自定义一个类
TYPE type_my_rec is record(
empno number,
ename varchar2(10),
sal number
);
procedure sum_sal(deptno department.deptno%type,sum in out number);
function avg_sal(deptno department.deptno%type) return number;
end dbms_my;
--实现程序包
create or replace package body dbms_my
is
procedure sum_sal(p_deptno department.deptno%type,sum in out number)
is
sum number;
begin
select sum(sal) into sum from employee where deptno=p_deptno;
end sum_sal;
function avg_sal(deptno department.deptno%type) return number
is
result number;
begin
select avg(sal) into result from employee where deptno=p_deptno;
return result;
end avg_sal;
end dbms_my;
--测试程序包
declare
--使程序包中定义的记录类型来声明变量
emp_rec dbms_my.type_my_rec;
v_deptno number default 7879;
sum_sal number;
avg_sal number;
x varchar2(100) := 'default value';
begin
emp_rec.empno := 7879;--给类中的某个属性赋值
sum_sal := dbms_my.sum_sal(deptno);--调用过程
dbms_output.put_line(sum_sal);--输出结果
select dbms_my.avg_sal(7879) into avg_sal from dual;--调用函数
dbms_output.put_line(avg_sal);--输出结果
end;
/
内容总结
以上是互联网集市为您收集整理的oracle学习笔记(二十一) 程序包全部内容,希望文章能够帮你解决oracle学习笔记(二十一) 程序包所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。