pl/sql基础知识—pl/sql块介绍
n 介绍
块(block)是pl/sql的基本成型单元,编写pl/sql程序实际上就是编写pl/sql块。要完成相对简单的应用功能,可能只需要编写一个pl/sql块;但是如果要想实现复杂的功能,可能需要在一个pl/sql块中嵌套其它的pl/sql块。、
n 块结构示意图
pl/sql块由三个部分构成:定义部分、执行部分、例外处理部分,如下所示:
n 案例1--只包括执行部分的pl/sql块。
案例:输出hello,world
☞相关说明:
dbms_output是oracle所提供的包(类似java的开发包),该包包含一些过程,put_line就是dbms_output包的一个过程。
SQL>
set serveroutput on; //打开控制台显示,默认不输出,需要执行此命令才会输出显示
SQL>
SQL>
begin
2
dbms_output.put_line('hello,world');
3
end;
4 /
hello,world
PL/SQL
procedure successfully completed
n 案例2--包括定义部分和执行部分的pl/sql块。
案例:根据用户输入的雇员编号,显示该雇员的名字
☞相关说明:
&
表示要接收从控制台输入的变量
‖表示把两个串拼接
declare --定义变量的格式:变量名称 变量的类型
v_ename varchar2(8);
begin
select
ename into
v_ename from
emp where
empno=&empno;--把查询的ename值放入v_ename变量
---输出v_ename
dbms_output.put_line('雇员名是:'||v_ename);
end;
雇员名是:SMITH
PL/SQL
procedure successfully completed
将其改为过程
SQL>
create procedure pro3(in_empno number) is
2
v_ename varchar2(8);
3
begin
4
select ename into v_ename from emp where empno=in_empno;
5
dbms_output.put_line('雇员名是:'||v_ename);
6
end;
7 /
Procedure
created
SQL>
exec pro3(7369);
雇员名是:SMITH
PL/SQL
procedure successfully completed
n 案例3--包括定义部分和执行部分和例外处理部分。
为了避免pl/sql程序的运行错误,提高pl/sql的健壮性,应该对可能的错误进行处理,这个很有必要:
①比如在案例2中,如果输入了不存在的雇员号,应当做例外处理
②有时出现异常,希望用另外的逻辑处理,比如:如果不存在就加入编号为1,名字为‘马大哈’这么一个人。
我们看看如何完成①的要求
相关说明:oracle事先预定义了一些例外,no_data_found就是找不到数据的例外。
SQL> declare
2
v_ename varchar2(8);
3
begin
4
select ename into v_ename from emp where empno=&empno;
5
dbms_output.put_line('雇员名是:'||v_ename);
6
exception
7 when no_data_found then
8
dbms_output.put_line('朋友,你输入的编号有误');
9
end;
10 /
朋友,你输入的编号有误
PL/SQL procedure successfully
completed
对该案例的细节说明:这里我们涉及到异常处理,
异常处理的基本语法:
exception
when 异常的名称
then
//对异常进行处理的代码......
//对异常进行处理的代码......
when 异常的名称2
then
//对异常进行处理的代码......
end;
oracle提供的异常有:(参考pl/sql官方文档)大概23种
有时可以利用异常来进行业务处理。比如:如果不存在就加入编号为1,名字为‘马大哈’这么一个人。
SQL> declare
2
v_ename varchar2(8);
3
begin
4
select ename into v_ename from emp where empno=&empno;
5
dbms_output.put_line('雇员名是:'||v_ename);
6
exception
7
when no_data_found then
8
dbms_output.put_line('朋友,你输入的编号有误!我帮你加入一条');
9
insert into emp (empno,ename) values(1,'马大哈');
10
end;
11 /
朋友,你输入的编号有误!我帮你加入一条
PL/SQL procedure successfully
completed
pl/sql基础知识—pl/sql块介绍的更多相关文章
- [SQL] SQL 基础知识梳理(一)- 数据库与 SQL
SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...
- [SQL] SQL 基础知识梳理(二) - 查询基础
SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(三) - 聚合和排序
SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...
- [SQL] SQL 基础知识梳理(四) - 数据更新
SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(五) - 复杂查询
SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...
- [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式
SQL 基础知识梳理(六)- 函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...
- [SQL] SQL 基础知识梳理(七)- 集合运算
SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...
- 常见SQL语句和SQL基础知识
引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name k ...
- [SQL基础教程]1-4 SQL 表的创建
[SQL基础教程]1-4 SQL 表的创建 创建数据库 语法 CREATE DATABASE <数据库名称> // example CREATE DATABASE shop; 创建表 语法 ...
随机推荐
- 2018-2019-2-20175332-实验四《Android程序设计》实验报告
一.Android Stuidio的安装测试 题目要求: 参考http://www.cnblogs.com/rocedu/p/6371315.html#SECANDROID,安装 Android St ...
- SQL Server作业的备份
作业备份,不是备份数据库,是备份作业.我的方法是把作业导出成文件备份起来,因为当你服务器维护的多了的时候很多你的作业 就很成问题,很麻烦.最好能够作业实现同步,这个也是第一步,保存成文件,之后个人设想 ...
- Java面试总结-基础篇2
1. mvn的dependency-management dependency-management是声明依赖,不实际引入,主要用于在父依赖中统一各依赖的版本,否则,各个子模块在引用同一依赖时,难免会 ...
- Google 和 微软,就不是一个重量级的
看微软的 WinCE 模拟器,做得带模带样 Google 也不是新来的,但是 Android 模拟器,配置一下都那么费事 这就是差距,Google 比 微软 差了好几级
- 利用TensorFlow识别手写的数字---基于两层卷积网络
1 为什么使用卷积神经网络 Softmax回归是一个比较简单的模型,预测的准确率在91%左右,而使用卷积神经网络将预测的准确率提高到99%. 2 卷积网络的流程 3 代码展示 # -*- coding ...
- 对于ssm过程中的乱码问题的处理
首先是数据库乱码问题: 1.可以先检测一下是否是数据库的问题: 可以先输入查询语句SHOW VARIABLES LIKE 'character_set_%';,查看所有的编码是否是UTF-8. (一般 ...
- Linux驱动手动绑定和解绑定方法
linux内核从2.6.13-rc3开始,提供了在用户空间,可动态的绑定和解绑定设备和设备驱动之间关系的功能.在这之前,只能通过insmod(modprobe)和rmmod来绑定和解绑,而且这种绑定和 ...
- springcloud的服务提供者与服务消费者
1.说明 springcloud中由服务消费者调用服务提供者一共有两种方法rest和feign 2.feign (1)使用feign的方式进行服务调,搭建服务提供者. 创建一个web项目(服务提供者) ...
- 开发者说 | 分布式事务中间件 Seata 的设计原理
导读 微服务架构体系下,我们可以按照业务模块分层设计,单独部署,减轻了服务部署压力,也解耦了业务的耦合,避免了应用逐渐变成一个庞然怪物,从而可以轻松扩展,在某些服务出现故障时也不会影响其它服务的正常运 ...
- TZ_09_MyBatis的pageHelper
1.分页操作使用MyBatis的PageHelper 1>导入pageHelper的坐标 <dependency> <groupId>com.github.pagehel ...