函数的应用

创建示例:
13、数据库 函数

--函数      创建或替换    函数          参数1                参数2
create or replace function ytInvest(amount numeric(15,2),deadline bigint) returns numeric(15,2) 
AS $$   --程序开始
declare     --声明
i integer;  --变量
total numeric(15,2):=0.00; 
rate numeric(15,2):=0.00; 
begin   --开始
i:=1; 
FOR i IN 1..deadline LOOP --循环 从变量i=1 到deadline
select r_income_rate into rate from t_product_earning_rate where r_product_id = 1 and r_month = i; 
total := total + amount*i*rate; 
end loop; 
total := total/12/100; 
return total; 
end; 
$$ 
LANGUAGE plsrsql VOLATILE 
COST 100;

函数一般用于计算和返回一个值,可以将经常需要使用的计算或功能写成一个函数。

1.创建函数:

函数的创建语法与存储过程比较类似,它也是一种存储在数据库中的命名程序块,函数可以接受

零或多个输入参数,并且函数必须有返回值(而这一点存储过程是没有的),其定义语法格式如下:

create [or replace] function fun_name[(parameter1[,parameter2]…) return data_type is

[inner_variable]

begin

plsql_ sentence;

[exception]

[dowith _ sentences;]

end [fun_name];

fun_name:函数名称,如果数据库中已经存在了此名称,则可以指定“or replace”关键字,这样新的函数将覆盖掉原来的函数。parameter1:函数的参数,这是个可选项,因为函数可以没有参数。data_type:函数的返回值类型,这是个必选项。在返回值类型的前面要使用return 关键字来标明。inner_variable:函数的内部变量,它有别于函数的参数,这是个可选项。plsql_ sentence:PL/SQL 语句,它是函数主要功能的实现部分,也就是函数的主体。dowith _ sentences:异常处理代码,也是PL/SQL 语句,这是一个可选项。由于函数有返回值,所以在函数主体部分(即begin 部分)必须使用return 语句返回函数值,并且要求返回值的类型要与函数声明时的返回值类型(即data_type)相同。

案例:定义一个函数,用于计算emp 表中指定某个部门的平均工资,代码及运行结果如下:

SQL> create or replace function get_avg_pay(num_deptno number) return number is //创建一个函数,该函数实

现计算某个部门的平均工资,传入部门编号参数

num_avg_pay number; //保存平均工资的内部变量

begin

select avg(sal) into num_avg_pay from emp where deptno=num_deptno; //某个部门的平均工资

return(round(num_avg_pay,2)); //返回平均工资

exception

when no_data_found then //若此部门编号不存在

dbms_output.put_line('该部门编号不存在');

return(0); //返回平均工资为0

end;

/

函数已创建

2.调用函数

由于函数有返回值,所以在调用函数时,必须使用一个变量来保存函数的返回值,这样函数和这个变量就组成了一个赋值表达式。以调用上面的get_avg_pay 函数为例,看看如何调用函数。案例:调用函数 get_avg_pay,计算部门编号为10 的雇员平均工资并输出,代码如下。

SQL> set serveroutput on

SQL> declare

avg_pay number; //定义变量,存储函数返回值

begin

avg_pay:=get_avg_pay(10); //调用函数,并获取返回值

dbms_output.put_line('平均工资是:'||avg_pay); //输出返回值,即员工平均工资

end;

/

3.删除函数

删除函数的操作比较简单,使用drop function 命令,其后面跟着要删除的函数名称,其语法格式如下:

drop function fun_name;

你可能感兴趣的:(函数的应用)