Oracle存储过程、包详解


1.pl/sql块介绍


1.1、只包括执行部分的pl/sql块

SQL>set serveroutput on --打开输出选项

begin /执行部分——要执行的pl/sql语句和sql语句/

dbms_output.put_line(‘hello’);

end;

/

/dbms_output是oracle所提供的包(类似java的开发包),该包包含一些过程,put_line就是dbms_output包的一个过程/

包含定义部分和执行部分的pl/sql块

1.2、包含定义部分和执行部分的pl/sql块

SQL>declare

v_ename varchar2(5); --定义字符串变量

begin

select ename into v_ename from emp where empno=&aa;

dbms_output.put_line(‘雇员名:’||v_ename);

end;

/

1.3、 包含定义部分,执行部分和例外处理部分的pl/sql块

SQL>declare

–定义变量

v_ename varchar2(5);

v_sal number(7,2);

begin

–执行部分

select ename,sal into v_ename,v_sal from emp where empno=&aa;

–在控制台显示用户名

dbms_output.put_line(‘用户名是:’||v_ename||’ 工资:'||v_sal);

–异常处理

exception

when no_data_found then

dbms_output.put_line(‘朋友,你的编号输入有误!’);

end;

/

2.pl/sql分类


2.1、过程

SQL>create procedure sp_pro(spName varchar2, newSal number) is

begin

–执行部分,根据用户名去修改工资

update emp set sal=newSal where ename=spName;

end;

/

SQL>exec sp_pro1(‘SCOTT’,4556); --调用

2.2、函数

–输入雇员的姓名,返回该雇员的年薪

SQL>create function annual_incomec(name varchar2)

return number is

annual_salazy number(7,2);

begin

–执行部分

select sal*12+nvl(comm, 0) into annual_salazy from emp where ename=name;

return annual_salazy;

end;

/

–在sqlplus中调用函数

SQL>var income number

call annual_incomec(‘SCOTT’) into: income;

print income

2.3、 包

–包用于在逻辑上组合过程和函数,它由包规范和包体两部分组成。

实例1:

–创建一个包sp_package

–声明该包有一个过程update_sal

–声明该包有一个函数annual_income

SQL>create package sp_package is

procedure update_sal(name varchar2, newsal number);

function annual_income(name varchar2) return number;

end;

/

实例2:

–给包sp_package实现包体

SQL>create or replace package body sp_package is

procedure update_sal(name varchar2, newsal number)

is

begin

update emp set sal = newsal where ename = name;

end;

function annual_income(name varchar2) return number is

annual_salary number;

begin

select sal * 12 + nvl(comm, 0) into annual_salary from emp

where ename = name;

return annual_salary;

end;

end;

/

如何调用包的过程或是函数

SQL> call sp_package.update_sal(‘SCOTT’, 1500);

2.4、触发器

常用的触发事件包括insert,update,delete语句,而触发操作实际就是一个pl/sql块。可以使用create trigger来建立触发器。

3.定义并使用变量,复合类型


3.1、标量定义的案例
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

在面试前我整理归纳了一些面试学习资料,文中结合我的朋友同学面试美团滴滴这类大厂的资料及案例

MyBatis答案解析
由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

大家看完有什么不懂的可以在下方留言讨论也可以关注。

觉得文章对你有帮助的话记得关注我点个赞支持一下!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
407)]
由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

大家看完有什么不懂的可以在下方留言讨论也可以关注。

觉得文章对你有帮助的话记得关注我点个赞支持一下!
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值