oracle嵌套子程序

剑破冰山学习笔记:

嵌套子程序的说明:

将一个子程序定义在一个PL/SQL块中的,该子程序称为嵌套子程序。
•只有定义在具名块中,才能存储到数据库中,匿名块里是无法存储到数据库的
区别
–函数和过程是Schema级别的子程序,包里的函数和过程,是Package级别的子程序。这两类都不是嵌套子程序。
声明
–嵌套子程序可以同时声明和定义,也可以先声明,然后在同一个PL/SQL块内再定义。后者称为”前置声明“。

具体示例:

在匿名块中使用。

declare
function aa(a number) return number
as
begin
return a*5;
end;
begin
dbms_output.put_line(aa('2'));
end;
 直接声明并且调用。

 

可以对函数进行重构,也就是定义两个相同的名称。

declare
function aa(a number) return number
as
begin
return a*5;
end;
function aa(a varchar2)return number
as
begin
return to_number(a)*15;
end;
begin
dbms_output.put_line(aa('2'));  --修改此处可以看出区别
end;

也可以在函数和存储过程的定义中使用,一下为存储过程的例子:

create or replace procedure calctriangleareagirth_1 (a number ,b number ,ang number)
as
function calcareabytwoside_ang(a number,b number,ang number) return number
as
rad number;
s number;
begin
  rad:=ang/180*(asin(1)*2);
  s:=round(a*b*sin(rad)/2,2);
  return s;
end;


function calcgirthbytwosides_ang(a number ,b number, ang number) return number
as
rad number;
c number;
g number;
begin
  rad:=ang/180*(asin(1)*2);
  c:=sqrt(a**2+b**2-2*a*b*cos(rad));
  g:=round(a+b+c,2);
  return g;
end;

begin
  dbms_output.put_line('area:' || to_char(calcareabytwoside_ang(a,b,ang)) || '   girth:'|| to_char(calcgirthbytwosides_ang(a,b,ang)));
end;
 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值