在Oracle中通过使用子程序和包将PL/SQL代码封装起来,从而实现模块化,在以后的调用中可以多次复用,而不受前台语言的限制,同时通过用子程序和包将PL/SQL代码封装起来,有利于提高开发效率和执行效率,但是维护性却没有面向对象灵活,如果一个子程序受到影响,就需要修改该子程序的定义。
在Oracle中子程序分为过程和函数,过程适用的场合是处理需要修改数据的业务,如有insert、delete、update、commit、rollback和有异常的地方;而函数适合于处理只是计算,而不必改变数据的场合,它通过返回值返回计算结果,它可以直接用在sql语句和jdbc中。过程的定义方法如下:
create or replace procedure add_emp(
p_ename emp.ename%type,
p_sal emp.sal%type,
p_hiredate varchar2, --不能写长度
p_empno out emp.empno%type
)
as
begin
insert into emp(empno,ename,sal,hiredate)
values(seq1.nextval,p_ename,p_sal,to_date(p_hiredate,'yyyy-mm-dd'))
returning empno into p_empno;
commit;
end;
而调用方式与使用jdbc基本相同,不同点就是
String sql = "{ call del_emp(?) }";
CallableStatement call =conn.prepareCall(sql);
方式调用函数。
函数创建方式:
create or replace function add_sal(
p_sal1 number,
p_sal2 number)
return number
as
v_sal emp.sal%type;
begin
v_sal:=p_sal1+p_sal2;
return v_sal;
end;
在Oracle中包适用于当过程和函数需要分类管理时使用,不同的包相当于不同的容器,先定义包规范,然后再包中实现包规范,包的定义方法如下:
--定义包规范
create or replace package mybao
is
procedure hello(v1 varchar2);
function double_num(v1 number)returnnumber;
end;
--然后在包体中实现
create or replace package body mybao
is
procedure hello(v1 varchar2)
as
begin
dbms_output.put_line('hello');
end;
function double_num(v1 number)returnnumber
as
begin
returnv1*2;
end;
end;
分享到:
相关推荐
oracle数据库中的子程序和包的简单用法,适用于刚入门的菜鸟学习
Oracle PL/SQL 子程序和包的概念和应用 本章要点: * 理解子程序(过程、函数)及包的概念 * 掌握如何创建、执行和删除过程、函数及包的方法 * 了解形参和实参的区别以及不同参数模式的特征 * 灵活使用过程、函数...
Oracle PL/SQL 讲义第 23 章 使用子程序和包 本章要点: * 掌握存储子程序与数据字典的交互方式及如何从 SQL 语句中调用存储子程序 * 了解存储子程序和局部子程序的区别 * 掌握存储子程序在 Oracle8i 和 Oracle9i ...
Oracle SQL&PLSQL课件:第22章 创建子程序和包.ppt
【创建子程序和包】是数据库管理中的一个重要概念,它涉及到PL/SQL编程语言的使用。PL/SQL是Oracle数据库的编程语言,它允许开发者创建高效、可复用的代码结构,以处理复杂的数据库操作。 **子程序**分为两种类型:...
在Oracle数据库中,子程序(过程和函数)可以存储在数据字典中,成为存储子程序,也可以作为局部子程序在PL/SQL语句块内部定义。存储子程序在创建后被编译成伪代码(p-code)存储在数据库中,可以被具有EXECUTE权限...
### Oracle 创建函数和包 #### 4.1 过程和函数 PL/SQL 的过程和函数类似于其他第三代编程语言(3GL)中的过程和函数,它们共享许多相同的特性。在 Oracle 中,过程和函数统称为子程序。下面将详细介绍过程和函数的...
共分为7部分(7个pdf文档): 第一部分:PL/SQL介绍及开发环境 1.PL/SQL介绍 2.PL/SQL开发和运行环境 3.跟踪和调试 ...4.创建子程序和包 5.使用子程序和包 6.数据库触发器 7.数据库作业和文件输入输出
3. **子程序(Subprogram)**:包括过程(Procedure)、函数(Function)和包(Package)。子程序能够存储在数据库中,这意味着一旦创建,它们就可以被多次调用而无需重新定义,提高了代码的重用性和效率。 4. **...
此外,PLSQL还有子程序(Subprogram)和包(Package)的概念,能够封装相关功能,提高代码复用性和模块化。 总之,“Oracle PLSQL9i 程序设计中的例子脚本”提供了丰富的示例,涵盖了PLSQL的基础语法、流程控制、...
Oracle Database 11g 标准课程第十一章 开发子程序和包过程-1