浏览 1936 次
锁定老帖子 主题:详细解读Oracle程序包
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2011-03-27
1:规范 ->规范中一般定义公用的变量、需要组织到程序包中的所有函数和存储过程都会出现在规范中. 2:主体 ->主体实现规范中定义的函数和存储过程,而且是必须实现 程序包事列 --创建程序包规换 --注意一下几点: --1:函数不要写is过程的实现 --2:存储过程不要写as的过程的实现 --3:函数和存储过程不需要create or replace命令 --4:声明变量时不要用declare create or replace package pkg_students as student_str varchar2(500);--声明变量时不要用declare student_age number :=18; function get_student_string return varchar2; procedure update_student --函数和存储过程不需要create or replace命令 ( in_student_id in number, in_student_name in varchar2, in_student_age in number ); procedure delete_student(in_student_id in number); end pkg_students; --在数据字典中查看程序包的规范信息 select object_name,object_type,status from user_objects where lower(object_name)='pkg_students'; --创建程序包主体 --注意一下几点: --1:规范中的参数定义要和主体的中的参数定义要一致,参数名也不允许改动 --2:规范中定义的函数和存储过程必须在主体中全部实现 --3:在主体中实现函数时,不需要create or replace命令 create or replace package body pkg_students as --规范中函数体的实现get_student_string function get_student_string return varchar2 is begin declare cursor cu_pkg_student is select student_name from students order by student_id; student_name varchar2(20); back_row_string varchar2(500); begin open cu_pkg_student; --别忘了打开游标 fetch cu_pkg_student into student_name; while cu_pkg_student%found loop back_row_string := student_name || ',' || back_row_string ; fetch cu_pkg_student into student_name; end loop; return substr(back_row_string,1,length(back_row_string)-1); end; end get_student_string; --规范中更新学生信息的存储过程的实现update_student procedure UPDATE_STUDENT ( in_student_id in number,--参数的定义必须和主体中参数名称和类型一致 in_student_name in varchar2, in_student_age in number )as begin update students set student_name=in_student_name, student_age =in_student_age where student_id =in_student_id; commit; end UPDATE_STUDENT; --规范中删除学生信息的存储过程的实现delete_student procedure DELETE_STUDENT ( in_student_id in number )as begin delete from students where student_id = in_student_id; commit; end DELETE_STUDENT; end pkg_students; --调用程序包中参数和存储过程 select pkg_students.get_student_string() from dual; begin pkg_students.delete_student(10); end; select * from students; 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |