Oracle中PL/SQL的执行部分和各种流程控制
Oracle中PL/SQL的执行部分和异常部分
一.PL/SQL的执行部分。
赋值语句。
赋值语句分两种,一种是定义一个变量,然后接收用户的IO赋值;另一种是通过SQL查询结果赋值。
用户赋值举例:
set serveroutput on;
accept abc prompt '请输入abc的值';
DECLARE
a int:= &abc;
BEGIN
dbms_output.put_line(a);
END;
查询赋值举例:
set serveroutput on;
DECLARE
str varchar2(20);
BEGIN
select ename into str from emp where empno='7369';
dbms_output.put_line(str);
END;
- 流程控制语句。
PL/SQL的主要控制语句如下:
1.if...then elsif … then end if;
判断if正确则执行then,否则执行else(elsif为嵌套判断)
注意elsif,里面少一下e.
2.Case var when … then when … then end
有逻辑的从数值中做出选择
3.Loop exit end loop
循环控制,用判断语句执行exit
4.Loop exit when … end loop
同上,当when为真时执行exit
5.while..loop end loop
当while为真时循环
6.for...in...loop end loop
已知循环次数的循环
因为流程控制比较多,在这里就不一一举实例了,写几个比较经典的程序给大家看一下。
********打印9*9乘法表*********
for in..loop
set serveroutput on;
DECLARE
i number;
j number;
BEGIN
for i in 1..9 loop
for j in 1..i loop
dbms_output.put(i||'*'||j||'='||(i*j)||' ');
end loop;
dbms_output.put_line('');
end loop;
END;
while loop
set serveroutput on;
declare
i number:=1;
j number:=1;
begin
while i<10 loop
while j<=i loop
dbms_output.put(i||'*'||j||'='||(i*j)||' ');
j:=j+1;
end loop;
i:=i+1;
j:=1;
dbms_output.put_line('');
end loop;
end;
*********计算1+2+..+10的值*********
loop exit & loop exit when
set serveroutput on;
declare
i number:=1;
i_sum number:=0;
begin
loop
i_sum:=i_sum+i;
i:=i+1;
if i>10 then
exit;
end if;
end loop;
dbms_output.put(i_sum);
dbms_output.put_line('');
end;
注意:put只是把输出结果放入缓冲区,直到遇到put_line时才会输出。所以只有put的时候,不会显示i_sum的结果。
可以把 if i>10 then exit; end if; 换成exit when i>10;这样就成为了loop ..exit when .. end loop 结构。
*********输入一个字符,判断是字母、数字还是其他字符****************
if then elsif else
set serveroutput on;
declare
i_char varchar2(2);
begin
i_char:=&abc;
if regexp_like(i_char,'^[a-z]$') then
dbms_output.put_line('输入的是字母');
elsif regexp_like(i_char,'^[0-9]$') then
dbms_output.put_line('输入的是数字');
else
dbms_output.put_line('输入的是其他字符');
end if;
end;
case when
set serveroutput on;
declare
i_char varchar2(2);
i_result varchar2(30);
begin
i_char:=&abc;
i_result:=
case
when regexp_like(i_char,'^[a-z]$') then
'输入的是字母'
when regexp_like(i_char,'^[0-9]$') then
'输入的是数字'
else
'输入的是其他字符'
end;
dbms_output.put_line(i_result);
end;
注意:在提示窗口中输入的时候,字符串一定要加单引号,否则就会出错,本人每次在这里都要拌一下。
- SQL语句
SQL语句就是数据库查询语句,比较简单就不在这里说了。
- 游标语句
二.异常部分。
数据库中的异常跟java中的异常的机制和作用原理是一样的,只是代码和格式不一样,数据库中的异常分为三类:系统异常(预定义异常)、自定义异常以及引发应用程序异常。
- 系统异常
例如:无法建立到Oracle的连接或用0做除数。好的程序应该对可能发生的异常情况进行处理,异常处理代码在EXCEPTION块中实现
可以使用WHEN语句来定义异常。WHEN语句的使用方法如下:
EXCEPTION
WHEN <异常情况名> THEN
<异常处理代码>
WHEN <异常情况名> THEN
<异常处理代码>
...
WHEN OTHERS THEN
<异常处理代码>
常见的系统异常
| 异常名称 | 异常码 | 说明 |
| NO_DATA_FOUND | ORA-01403 | select into语句中没有返回任何记录 |
| TOO_MANY_ROWS | ORA-01422 | select into语句中返回多行数据。 |
| ZERO_DIVDE | ORA-01476 | 试图用0作为除数。 |
| DUP_VAL_ON_INDEX | ORA-00001 | 试图向唯一索引列插入重复值 |
| INVALID_CURSOR | ORA-01001 | 试图进行非法游标操作。 |
| CURSOR_ALREADY_OPEN | ORA-06511 | 试图打开一个已经打开的游标。 |
| INVALID_NUMBER | ORA-01722 | 试图将数字转换为字符串。 |
| VALUE_ERROR |
在产生大小限制错误时出现。如,变量中的列值超出变量的大小 |
|
|
LOGIN_DENIED |
输入的用户名或者密码无效时出现。 |
- 自定义异常
当与一个异常错误相关的错误出现时,就会隐含触发该异常错误。用户定义的异常错误是通过显式使用 RAISE 语句来触发。当引发一个异常错误时,控制就转向到 EXCEPTION块异常错误部分,执行错误处理代码。
对于这类异常情况的处理,步骤如下:
在PL/SQL 块的定义部分定义异常情况:
<异常名称> exception;
在PL/SQL 块的执行部分RAISE异常:
RAISE <异常名称>;
在PL/SQL 块的异常情况处理部分对异常情况做出相应的处理。
WHEN <异常名称> THEN
代码...
- 引发应用程序异常
Oracle中PL/SQL的执行部分和各种流程控制的更多相关文章
- Oracle中PL/SQL简介、基本语法以及数据类型
Oracle中PL/SQL简介.基本语法以及数据类型 一.PL/SQL简介. Oracle PL/SQL语言(Procedural Language/SQL)是结合了结构化查询和Oracle自身过程控 ...
- 使用oracle 的 PL/Sql 定时执行一个存储过程
CSDN日报20170322--<关于软件研发的一些体会总结> 同步博客至 CSDN ,让更多开发者看到你的文章 看微博技术大咖解析互联网应用架构实战 使用oracle 的 PL/Sql ...
- Oracle中PL/SQL的循环语句
在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...
- Oracle中PL/SQL 范例
1.写匿名块,输入三角形三个表的长度.在控制台打印三角形的面积 declare v_side_first ):=&第一条边; v_side_second ):=&第二条边; v_sid ...
- oracle中pl/sql 练习题----输入部门编号,在控制台打印这个部门的名称,总人数,平均工资(基本工资+奖金)
一. 思路:声明record类型的变量,根据 多表联合查询查出想要的数据,最后输出. 二.注意:record类型不一定只是一个表中的数据,也可以声明不同表中的数据类型. 三.语句如下: declare ...
- oracle中动态SQL详解
部分内容参考网上资料 1.静态SQLSQL与动态SQL Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情 ...
- oracle中动态SQL使用详细介绍
Oracle编译PL/SQL程序块分为两个种:通常静态SQL采用前一种编译方式,而动态SQL采用后一种编译方式,需要了解的朋友可以参考下 1.静态SQLSQL与动态SQL Oracle编译PL ...
- (转)Oracle中动态SQL详解
本文转载自:http://www.cnblogs.com/gaolonglong/archive/2011/05/31/2064790.html 1.静态SQLSQL与动态SQL Oracle编译PL ...
- [转载]Oracle中动态SQL详解
1.静态SQLSQL与动态SQL Oracle编译PL/SQL程序块分为两个种:其一为前期联编(early binding),即SQL语句在程序编译期间就已经确定,大多数的编译情况属于这种类型:另外一 ...
随机推荐
- Centos7 修改mysql指定用户的密码
1.登陆mysql或者mariadb(两种任选其一) [root@localhost ~]# mysql -u root [root@localhost ~]# mysql -uroot -p 2.切 ...
- LeetCode之389. Find the Difference
-------------------------------------------------- 先计算每个字母的出现次数然后减去,最后剩下的那一个就是后来添加的了. AC代码: public c ...
- 移动APP项目研发流程及版本规划(转)
一个移动APP项目研发规模可大可小,但都离不开以下几个成员:产品经理.ui设计师.前端开发.后端开发.测试等.如何合理安排项目成员工作.确保项目顺利进行呢?一个清晰合理的项目研发流程控制很重要. 项目 ...
- SeekBar进度条简单案例
SeekBar是进度条.我们使用进度条时,可以使用系统默认的进度条:也可以自定义进度条的图片和滑块图片等 向右拉进度条让图片显示出来 向右拉五角星加载有色进度条 baseSeekBar package ...
- Light oj1031 Easy Game (区间dp)
题目链接:http://vjudge.net/contest/140891#problem/F A和B都足够聪明,只有我傻,想了好久才把代码和题意对应上[大哭] 代码: #include<ios ...
- zookeeper选举原理
zookeeper的领导者选举和原子广播 目录: 1.工作原理概述 2.Fast Leader选举算法(领导者选举) 3.Leader与Follower同步数据(原子广播) ...
- 一个获取指定目录下一定格式的文件名称和文件修改时间并保存为文件的python脚本
摘自:http://blog.csdn.net/forandever/article/details/5711319 一个获取指定目录下一定格式的文件名称和文件修改时间并保存为文件的python脚本 ...
- 移植tslib1.4至mini2440
在移植tslib1.4至mini2440的过程中出现了一些问题,在解决问题的过程中也学到了不少东西.但是由于注意力不集中也导致了一些低级的错误,非常地浪费时间,以后在做事的时候必须集中注意力,宁愿慢一 ...
- Linux安装软件时缺少依赖包的简单较完美解决方法!
大家在linux下源码安装时,有木有经常碰到缺少这个包那个包的,然后不知所措?看到最近有几个筒子安装thrift,安装python因缺少依赖包而进行不下去了.我用的是红帽,装系统的时候习惯把所有的有的 ...
- 《bootstrap》实战---小问题,大Bug
参照书中代码写了个示例,能够实现大页面单行导航,小页面显示收缩按钮,但是就是不能让收缩按钮发挥作用.也不知道哪儿出了问题. 想想算了,代码也不多,重新来吧.写道导航的时候,突然发现一个<nav& ...