时间:2021-07-01 10:21:17 帮助过:13人阅读
语法:
create [or replace] function 函数名[(参数名1[in/out/inout] 参数类型...)]
return 返回值的类型
as/is
变量声明部分
begin
业务逻辑处理部分
return 变量/常量
exception
异常处理部分
end;
例子:创建一个函数,返回0到10之间的一个随机整数
1 调用函数一般使用匿名块: 2 create or replace function fun_random return number 3 is 4 -- 声明随机数变量 5 v_num number(5); 6 begin 7 --获取0到10之间的一个随机数 8 v_num:=trunc(dbms_random.value(0,10)); 9 return v_num; 10 end; 11 --通过匿名块调用函数 12 declare 13 -- 声明变量接收函数的返回值 14 v_num number(5); 15 begin 16 -- 调用函数 17 v_num:=fun_random(); 18 --打印结果 19 dbms_output.put_line(‘随机数:‘||v_num); 20 end;
在开发中,如果业务逻辑比较复杂,需要定义很多过程或者函数。有可能需要定义几十个过程或者函数,这些过程或者函数如果都放到一起,不好管理,一般使用包来管理过程或者函数,一个包中可以定义多个函数或者过程。
一个包包括包和包体,需要同时定义包和包体,这种写法类似于java中的接口和接口的实现。包相当于接口,包体相当于接口的实现类。
创建包的语法:
create [or replace] package 包名 is
-- 声明常量
-- 声明函数或者过程,但是不能有实现
end;
创建包体的语法:
create [or replace ] package body 包名 is
-- 包的实现
end;
例子:定义包,计算圆的面积
定义包:
1 -- 定义包 计算圆的面积 2 create or replace package pac_area is 3 -- 定义pi常量 4 v_pi constant number(5,2):=3.14; 5 --定义计算圆的面积的过程,打印圆的面procedure pro_area(v_r number); 6 --定义一个获取圆的面积的函数 7 function fun_area return number; 8 end;
创建包体:
1 -- 定义包体,用来实现包 2 create or replace package body pac_area is 3 --把面积参数定义成包体的成员变量,这样函数也可以使用这个变量 4 v_area number(5,2); 5 -- 实现过程 6 procedure pro_area(v_r number) is 7 begin 8 v_area:=v_pi*v_r*v_r; 9 dbms_output.put_line(‘圆的面积是:‘||v_area); 10 end; 11 --实现函数,注意,调用该函数前,一定要先调用过程 12 function fun_area return number ibegin 13 return v_area; 14 end; 15 end;调用包中的过程或者函数,在函数或者过程前加上包名就可以了: 16 --使用匿名块调用包中的过程和函数 17 declare 18 v_area number(5,2); 19 begin 20 -- 调用打印圆的面积的过程 21 pac_area.pro_area(2); 22 -- 调用获取圆的面积的函数 23 v_area :=pac_area.fun_area(); 24 dbms_output.put_line(‘函数计算的圆的面积是:‘||v_area); 25 end;
删除:
drop procedure 过程名;
drop function 函数名;
drop package 包名;
查询oracle中定义的包,函数,过程从user_source 表查找。
select * from user_source where type=‘PACKAGE BODY‘ and name = ‘PAC_AREA‘;
一、过程和函数什么时候用
过程一般用于返回多个参数,函数一般用户返回一个参数。
二、在pl/sql中 包的作用是什么
包的作用 封装,方便管理过程和函数。
oracle中的创建过程,函数,包
标签:定义 成员 cep 使用 turn 创建 不能 返回 random