`
357029540
  • 浏览: 735029 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

Oracle中的子程序和包

阅读更多
在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数据库中的子程序和包的简单用法,适用于刚入门的菜鸟学习

    Oracle_plsql讲义:第22章 创建子程序和包.ppt

    Oracle PL/SQL 子程序和包的概念和应用 本章要点: * 理解子程序(过程、函数)及包的概念 * 掌握如何创建、执行和删除过程、函数及包的方法 * 了解形参和实参的区别以及不同参数模式的特征 * 灵活使用过程、函数...

    Oracle_plsql讲义:第23章 使用子程序和包.ppt

    Oracle PL/SQL 讲义第 23 章 使用子程序和包 本章要点: * 掌握存储子程序与数据字典的交互方式及如何从 SQL 语句中调用存储子程序 * 了解存储子程序和局部子程序的区别 * 掌握存储子程序在 Oracle8i 和 Oracle9i ...

    Oracle SQL&PLSQL课件:第22章 创建子程序和包.ppt

    Oracle SQL&PLSQL课件:第22章 创建子程序和包.ppt

    创建子程序和包8.ppt

    【创建子程序和包】是数据库管理中的一个重要概念,它涉及到PL/SQL编程语言的使用。PL/SQL是Oracle数据库的编程语言,它允许开发者创建高效、可复用的代码结构,以处理复杂的数据库操作。 **子程序**分为两种类型:...

    数据库oracle触发器课件

    在Oracle数据库中,子程序(过程和函数)可以存储在数据字典中,成为存储子程序,也可以作为局部子程序在PL/SQL语句块内部定义。存储子程序在创建后被编译成伪代码(p-code)存储在数据库中,可以被具有EXECUTE权限...

    oracle 创建函数和包

    ### Oracle 创建函数和包 #### 4.1 过程和函数 PL/SQL 的过程和函数类似于其他第三代编程语言(3GL)中的过程和函数,它们共享许多相同的特性。在 Oracle 中,过程和函数统称为子程序。下面将详细介绍过程和函数的...

    Oracle8i PL/SQL高级程序设计 高清晰版

    共分为7部分(7个pdf文档): 第一部分:PL/SQL介绍及开发环境 1.PL/SQL介绍 2.PL/SQL开发和运行环境 3.跟踪和调试 ...4.创建子程序和包 5.使用子程序和包 6.数据库触发器 7.数据库作业和文件输入输出

    oracle 9i pl/sql程序设计笔记

    3. **子程序(Subprogram)**:包括过程(Procedure)、函数(Function)和包(Package)。子程序能够存储在数据库中,这意味着一旦创建,它们就可以被多次调用而无需重新定义,提高了代码的重用性和效率。 4. **...

    Oracle PLSQL9i 程序设计中的例子脚本

    此外,PLSQL还有子程序(Subprogram)和包(Package)的概念,能够封装相关功能,提高代码复用性和模块化。 总之,“Oracle PLSQL9i 程序设计中的例子脚本”提供了丰富的示例,涵盖了PLSQL的基础语法、流程控制、...

    Oracle Database 11g 标准课程第十一章 开发子

    Oracle Database 11g 标准课程第十一章 开发子程序和包过程-1

Global site tag (gtag.js) - Google Analytics