PL/SQL之--流程控制语句
一、简介
像编程语言一样,oracle PL/SQL也有自己的流程控制语句。通过流程控制语句,我们可以在PL/SQL中实现一下比较复杂的业务逻辑操作。而无需到程序中去控制,在一定程度上提高了效率,这也是PL/SQL的强大之处。PL/SQL流程控制语句有如下几种:
- 控制语句: 包括IF 语句、CASE语句
- 循环语句: 包括LOOP语句, WHILE语句、FOR语句
- 顺序语句: 包括GOTO语句
二、语句种类
1、控制语句
a、IF语句
语法如下:
IF 条件语句 TEHN 执行语句
ELSIF 条件语句 TEHN 执行语句
ELSE 执行语句
END IF;
示例如下:
DECLARE
i number;
str VARCHAR2(18) := 'b';
BEGIN
--数字判断
if(i = 6) THEN
NULL; -- 如果什么都不做建议写null,保证语句的完整性
ELSIF(i is null) THEN
dbms_output.put_line('null');
ELSE
dbms_output.put_line('null');
END IF; -- 字符串判断
if(str = 'a') THEN
dbms_output.put_line('if');
ELSIF (str = 'b') THEN
dbms_output.put_line('elsif');
ELSE
dbms_output.put_line('else');
END IF;
END;
b、CASE语句
语法如下:
1、变量判断
CASE 变量
WHEN 值 THEN 执行语句
WHEN 值 THEN 执行语句
END CASE;
2、表达式判断
CASE
WHEN 表达式 TEHN 执行语句
WHEN 表达式 TEHN 执行语句
END CASE;
示例代码如下:
DECLARE
str VARCHAR2(18) := 'B';
num NUMBER := 60;
strresult VARCHAR2(10);
numresult VARCHAR2(10);
BEGIN
-- 变量判断
CASE str
WHEN 'A' THEN strresult := '优秀';
WHEN 'B' THEN strresult := '良好';
WHEN 'C' THEN strresult := '合格';
WHEN 'D' THEN strresult := '不及格';
END CASE;
--表达式判断
CASE
WHEN num < 60 THEN numresult := '不及格';
WHEN num < 70 THEN numresult := '合格';
WHEN num < 70 THEN numresult := '良好';
WHEN num < 70 THEN numresult := '优秀';
END CASE; dbms_output.put_line(strresult);
dbms_output.put_line(numresult);
END;
2、循环语句
a、LOOP语句
语法如下:
LOOP
执行语句
EXIT WHEN 条件
END LOOP;
示例代码:
DECLARE
i NUMBER := 0 ;
BEGIN
LOOP
i := i + 1 ;
dbms_output.put_line (i) ;
EXIT WHEN i = 5 ;
END LOOP ;
END ;
b、WHILE语句
语法如下:
WHILE 条件 LOOP
执行语句
END LOOP;
-- 打印i每次增加后的值
DECLARE
i NUMBER := 0 ;
BEGIN
WHILE i < 5 LOOP
i := i + 1 ;
dbms_output.put_line ('i:' || i) ;
END LOOP ;
END ;
c、FOR语句
语法如下:
FOR 变量 IN (REVERSE) 数字 .. 数字 LOOP
执行语句
END LOOP;
加上REVERSE就是数字的逆序。
示例代码如下:
-- index 是for开始就定了的
BEGIN
-- 打印1到5之前的数
FOR i IN 1 .. 5 LOOP
dbms_output.put_line ('i:' || i) ;
END LOOP ;
-- 打印5-到20的数,逆序打印
FOR j IN REVERSE 5 .. 20 LOOP
dbms_output.put_line ('j:' || j) ;
END LOOP ;
END ;
3、顺序语句
a、GOTO语句
语法如下:
GOTO label;
GOTO语句一般都是由某行跳到另外一行。
示例代码如下:
DECLARE
i NUMBER := 1 ;
BEGIN
loop
dbms_output.put_line (i) ;
i := i + 1 ;
IF i = 10 THEN
GOTO label ;
END IF ;
END loop ;
<< label >>
dbms_output.put_line ('label') ;
END;
本例子就i一直循环加一,当i等于10时,跳出循环,跳到第11行并执行。
PL/SQL之--流程控制语句的更多相关文章
- Sql Server 流程控制语句
T-SQL中用来编写流程控制模块的语句有:BEGIN...AND语句.IF...ELSE语句.CASE语句.WHILE语句.GOTO语句.BREAK语句.WAITFOR语句和RETURN语句. 批处理 ...
- PL/SQL 03 流程控制
--IF语法IF condition THEN statements;[ELSIF condition THEN statements;][ELSE statements;]END IF; -- ...
- PL/SQL流程控制语句
PL/SQL流程控制语句介绍PL/SQL的流程控制语句, 包括如下三类:控制语句: IF 语句循环语句: LOOP语句, EXIT语句顺序语句: GOTO语句, NULL语句①if语句 IF < ...
- [推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆)
原文:[推荐]ORACLE PL/SQL编程详解之三:PL/SQL流程控制语句(不给规则,不成方圆) [推荐]ORACLE PL/SQL编程详解之三: PL/SQL流程控制语句(不给规则,不成方圆) ...
- oracle数据库之PL/SQL 流程控制语句
介绍 PL/SQL 的流程控制语句, 包括如下三类: 1.控制语句: IF 语句 2.循环语句: LOOP 语句, EXIT 语句 3.顺序语句: GOTO 语句, NULL 语句 一 条件语句 IF ...
- PL/SQL程序设计、流程控制
PL/SQL是 Procedure Language & Structured Query Language 的缩写 PL/SQL是对SQL语言存储过程语言的扩展 PL/SQL程序由三个块组成 ...
- 【强烈强烈推荐】《ORACLE PL/SQL编程详解》全原创(共八篇)--系列文章导航
原文:[强烈强烈推荐]<ORACLE PL/SQL编程详解>全原创(共八篇)--系列文章导航 <ORACLE PL/SQL编程详解> 系列文章目录导航 ——通过知识共享树立个人 ...
- 浅谈PL/SQL语言基础
在前面的学习中,我们大部分接触的都是SQL语言,但是,在实现复杂操作的时候,SQL语言就无能为力了,这时候就需要引入新的语言,PL/SQL语言就是对SQL语言的扩展,可以实现存储过程,函数等的创建.下 ...
- Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分 一.PL/SQL的执行部分. 赋值语句. 赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值:另一种是通过SQL查询结果赋值. 用户赋值举例: ...
随机推荐
- Redis设计与实现-客户端服务端与事件
事件 redis服务器是事件驱动的,事件分为文件事件与时间事件 文件事件是服务器通过套接字与客户端连接,两者之间的通信会产生相应的文件事件,服务器监听并处理这些事件完成网络操作: 时间事件是指redi ...
- EF错误记录
纯属个人记录错误使用: 1.EntityType“area”未定义键.请为该 EntityType 定义键. 产生原因: 1.命名空间引用错误,可能命名重复导致引用错误 2.实体类无法识别主键或者未设 ...
- 后缀数组 --- HDU 3518 Boring counting
Boring counting Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=3518 Mean: 给你一个字符串,求:至少出 ...
- 重构第5天:提升字段(Pull Up Field)
理解:提升字段和前面讲解的方法提公很类似,可以说方式都是一样的.就是把继承类中经常用到的字段,提出来 放到基类中,达到通用的目的.提高代码重用性和可维护性. 详解:如下重构前的代码: using Sy ...
- 混合式APP开发中中间件方案Rexsee
发现Rexsee时,他已经一年多没有更新过了,最后版本是2012年的. 他的实现思路是通过Android自带的Java - Javascript 桥机制,在WebView中的JavaScript同Ja ...
- ASP.NET MVC进阶二
一.数据验证 数据验证的步骤 在模型类中添加与验证相关的特性标记 在客户端导入与验证相关的js文件和css文件 使用与验证相关的Html辅助方法 在服务器端判断是否通过服务器端验证 常用的验证标记 R ...
- postgresql 9.6 rc1发布
postgresql 9.6 rc1发布了,意味着postgresql 9.6正式版将会越来越近了. 对于dss来说,postgresql远优于mysql,尤其是9.6新引入的并行执行,将大大提高性能 ...
- WPF超级链接
一.添加样式 <Style x:Key="LinkLabelStyle"> <Setter Property="Control.Padding" ...
- Exchange 2013 、Lync 2013、SharePoint 2013
Office办公系列 在企业中广泛应用,目前服务的客户当中,部分客户已经应用到了 Exchange.Lync.CRM.SharePoint等产品,在开发当中多多少少会涉及到集成,为了更好的服务客户.了 ...
- 上载EXCEL到SAP系统的方法之一
TEXT_CONVERT_XLS_TO_SAP实例 使用:gui_upload去上传excel数据,每次都出现乱码,不管中文英文都乱码. 至今不知道gui_upload是否支持excel文件上传,. ...