oracle的存储过程和存储函数

存储过程

存储过程实际上是封装在服务器上的一段PLSQL代码片段(已经编译好了的代码)。用户通过指定存储过程的名字并给出参数(如果该存储过程带有参数)来执行它。
在这里插入图片描述
创建一个给某个员工加特定工钱的存储过程:

-- empid是用户输入的指定的员工id
-- insal是用户输入的指定的涨薪多少
-- currentsal是员工涨薪钱的目前工资

create or replace procedure cc1(empid in number,insal in number)
is
   currentsal number;
begin
  select sal into currentsal from emp1 where id=empid;
  dbms_output.put_line('his sal before is '||currentsal||'$');
  update emp1 set sal=sal+insal where id=empid;
  dbms_output.put_line('his sal after is '||(insal+currentsal)||'$');
  commit;
end;

在这里插入图片描述

存储过程的调用


-- 第一种
call  存储过程名(参数1, 参数2···);

-- 第二种
declare
begin
	存储过程名(参数1, 参数2···);
end;

在这里插入图片描述

call cc1(1005,3000);

在这里插入图片描述



存储函数

存储函数和存储过程基本都差不多,只是存储函数有返回值,存储过程没有。
在这里插入图片描述

存储函数的调用

declare
  变量1   类型;
begin
   变量1:=存储函数名(参数1,参数2···);
   dbms_output.put_line(变量1);
end;

范例:
在这里插入图片描述
创建一个查询某个员工的年薪的存储函数:


-- 输入参数的in标识可以省略
create or replace function emptotalsal(empid number) return number
is 
  fullyearsal number;
begin
  select sal*12+nvl(bonus,0) into fullyearsal from emp1 where id=empid;
  return fullyearsal;
end;


-- 调用存储函数emptotalsal
declare
  e number;
begin
   e:=emptotalsal(1007);
   dbms_output.put_line(e);
end;

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Brrby

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值