创建包和包体
什么是包和包体?
包是一组相关过程、函数、变量、常量、类型和游标等PL/SQL程序设计元素的组合。包具有面向对象设计的特点,是对这些PL/SQL程序设计元素的封装。
包体是包定义部分的具体实现。
包由两个部分组成:包定义和包主体。
--包定义 create [or replace] package 包名 as [公有数据类型定义] [公有游标声明] [公有变量、常量声明] [公有子程序声明] end 包名;
--包主体 create [or replace] package body 包名 as [私有数据类型定义] [私有变量、常量声明] [私有子程序声明和定义] [公有子程序定义] begin PL/SQL子程序体; end 包名;
--创建mypackage包 create or replace package mypackage as procedure total(num1 in number, num2 in number, num3 out number); end mypackage;
--mypackage包体 create or replace package body mypackage as --计算累加和的total过程 procedure total(num1 in number, num2 in number, num3 out number) as tmp number := num1; begin if num2 < num1 then num3 := 0; else num3 := tmp; loop exit when tmp > num2; tmp := tmp + 1; num3 := num3 + tmp; end loop; end if; end total; end mypackage;
(*注意:包定义和包体要分开创建)
调用包
declare num1 number; begin mypackage.total(1, 5, num1); dbms_output.put_line(num1); end;
更多关于Oracle相关内容感兴趣的读者可查看本站专题:《Oracle常用函数汇总》、《Oracle日期与时间操作技巧总结》及《php+Oracle数据库程序设计技巧总结》
希望本文所述对大家Oracle数据库程序设计有所帮助。