PL/SQL程序控制结构及在PL/SQL中更改数据和管理事务
A. IF条件分支语法:
if (条件1) then
语句;
elsif (条件2) then
语句;
elsif (条件3) then
语句;
else
语句;
end if;
B . case条件分支:等值比较、条件比较、case表达式
a.等值比较语法:
CASE 条件判断
WHEN 条件值的表达式 THEN 要执行的条件操作 ;
…….
[ELSE ……..]
END CASE;
b. 条件比较语法:
CASE
WHEN 不同比较条件 THEN 要执行的条件操作 ;
…….
[ELSE ……..]
END CASE;
2. 循环控制
A. 基本循环:无论是否满足条件,语句至少执行一次
语法:LOOP
……..
EXIT [WHEN 条件语句];
END LOOP;
B. WHILE循环:只有条件为真时,才会执行
语法: WHILE 条件语句 LOOP
…………………………………..
END LOOP;
C. FOR循环
语法: FOR 循环计数器 IN [REVERSE] 下限.. 上限 LOOP
……………………………………………………………………………………
END LOOP;
D. 嵌套循环和标号:定义标号:<< 标号名称 >>
3. 顺序控制
缺点是会增加程序的复杂性,降低可读性,所以Oracle建议昼不要使用。
B. NULL语句:空语句,执行没有任何实际效果,通常占位置用
4. 异常处理
A.异常有两种类型:
a. 预定义异常 : 当 PL/SQL 程序违反 Oracle 规则或超越系统限制时隐式引发
b. 用户定义异常 : 用户可以在 PL/SQL 块的声明部分定义异常,自定义的异常通过 RAISE 语句显式引发
B. 定义异常语法:异常名称 EXCEPTION;
PRAGMA EXCEPTION_INIT(异常名称, 错误号);
C. 抛出异常语法
a. RAISE 异常名称;
b. RAISE_APPLICATION_ERROR(错误号 , 错误描述 [, {TRUE|FALSE}]);
D. 处理异常语法
EXCEPTION
WHEN ……. THEN
…………….
WHEN THEN
WHEN OTHERS THEN
………….
5. DML操作的游标属性
A. 隐式游标
a. 名称:SQL
b. 属性:SQL%属性名
c. 常见属性
SQL%FOUND:操作到数据
SQL%NOTFOUND:没有操作到数据
SQL%ROWCOUNT:操作的记录数
B. DML语句的RETURNING字句:返回SQL执行以后的结果
6. 用ForAll语句批量执行DML
A. ForAll语句语法
ForAll 索引 in 开始..结束
sql语句; --注意,只有一句!
B . 在INSERT语句上使用批量绑定:首先要给集合元素赋值,然后再使用ForAll语句批量绑定
C. ForAll的游标属性
a. SQL%FOUND:操作到数据
b. SQL%NOTFOUND:没有操作到数据
c. SQL%ROWCOUNT:操作的记录数
d. SQL%BULK_ROWCOUNT:返回批量执行时第i个元素所作用的行数
7. PL/SQL中的数据库事务管理
A. 事务概念:事务就是一个完整的逻辑工作单元,由多个操作组成。所有操作要么全部成功,要么全部失败
B. 事务特点: ACID:原子性、一致性、隔离性、(永)持久性
C. 事务控制流程
开始事务
自动执行第一条SQL开始
执行SQL
可能执行多条SQL
提交或回滚
commit或rollback
D. 锁的概念:锁是数据库用来控制共享资源并发访问的机制、锁用于保护正在被修改的数据、直到提交或回滚了事务之后,其他用户才可以更新数据
E. 锁的类型:行级锁、表级锁
a.行级锁:对正在被修改的行进行锁定。其他用户可以访问除被锁定的行以外的行
在使用以下语句时,Oracle会自动应用行级锁:
a. INSERT
b. UPDATE
c. DELETE
d. SELECT … FOR UPDATE
使用COMMIT或ROLLBACK语句释放锁
b. 表级锁:锁定整个表,限制其他用户对表的访问
语法: LOCK TABLE table_name IN mode MODE;
F. 死锁:当两个事务相互等待对方释放资源时,就会形成死锁、Oracle会自动检测死锁,并通过结束其中的一个事务来解决死锁
8. 事务隔离级别
A. 分类
a. 未提交读
读其它用户没有提交的数据,又称脏读
b.提交读:Oracle支持,这也是默认支持的级别(可能会发生不可重复读数据异常)
c.可重复读: Oracle不支持(可能会发生幻读数据异常)
d.串行读: Oracle支持,不过效率低
9. 数据库事务实现机制:通过日志文件实现
PL/SQL程序控制结构及在PL/SQL中更改数据和管理事务的更多相关文章
- 使用Hive或Impala执行SQL语句,对存储在HBase中的数据操作
CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...
- 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作(二)
CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...
- 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作
http://www.cnblogs.com/wgp13x/p/4934521.html 内容一样,样式好的版本. 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据 ...
- sql语句 怎么从一张表中查询数据插入到另一张表中?
sql语句 怎么从一张表中查询数据插入到另一张表中? ----原文地址:http://www.phpfans.net/ask/MTc0MTQ4Mw.html 比如我有两张表 table1 字段 un ...
- 程序一 用记事本建立文件src.dat,其中存放若干字符。编写程序,从文件src.dat中读取数据,统计其中的大写字母、小写字母、数字、其它字符的个数,并将这些数据写入到文件test.dat中。
用记事本建立文件src.dat,其中存放若干字符.编写程序,从文件src.dat中读取数据,统计其中的大写字母.小写字母.数字.其它字符的个数,并将这些数据写入到文件test.dat中. #inclu ...
- sql存储过程通过ID删除两表中的数据。
CREATE OR REPLACE PROCEDURE del_p --建立名为del_p 的过程 IS CURSOR get_abid --简历名为get_abid的cursor 用来存放a表的id ...
- Oracle数据库之PL/SQL程序设计基础
PL/SQL程序设计基础 一.PL/SQL块结构 前边我们已经介绍了PL/SQL块的结构,再来回顾一下: DECLARE /* * 声明部分——定义常量.变量.复杂数据类型.游标.用户自定义异常 */ ...
- JDBC基础:JDBC快速入门,JDBC工具类,SQL注入攻击,JDBC管理事务
JDBC基础 重难点梳理 一.JDBC快速入门 1.jdbc的概念 JDBC(Java DataBase Connectivity:java数据库连接)是一种用于执行SQL语句的Java API,可以 ...
- 二十五、oracle pl/sql进阶--控制结构(分支,循环,控制)
一.pl/sql的进阶--控制结构在任何计算机语言(c,java,pascal)都有各种控制语句(条件语句,循环结构,顺序控制结构...),在pl/sql中也存在这样的控制结构.在本部分学习完成后,希 ...
随机推荐
- Linux常用命令——关机与重启命令
1.shutdown命令 shutdown [选项] 时间 --使用shutdown进行关机或重启会正确保存正在使用的服务,其他命令有一定的危险性,建议最好使用shutdown命令进行关机重启 选项: ...
- Linux kernel 内存 - 页表映射(SHIFT,SIZE,MASK)和转换(32位,64位)
0. Intro 如下是在32位下的情况,32位下,只有三级页表:PGD,PMD,PTE 在64位情况下,会有四级页表:PGD,PUD,PMD,PTE 但是原理基本上是一样的,本文主要是想记录一下页表 ...
- TWaver MONO Design中动画的导出与播放
使用过MONO编辑器的朋友都应该了解MONO中支持一些动画的设置,比如开门,开窗,弹出设备,旋转场景,镜头巡航等.但如何将这些动画应用到自己的场景中呢?比如我们在编辑器中给机柜定义了动画,怎样让做好的 ...
- 我的ACM技能框架(自用)
每次接触到新的知识就把它名字记下来,留给以后当纪念 2018.11 已经学会的 滚动数组,前缀和优化 对多维数组在空间复杂度上的降维优化 最长上升子序列 LIS问题,动态规划递推解决 最长不下 ...
- iframe使用大全
<iframe src=”you page’s url” width=”100″ height=”30″ frameborder=”no” border=”0″ marginwidth=”0″ ...
- odoo domain详解
参考的以下文档: luohuayong:Odoo domain写法及运用 baimo:odoo domain表达式 1.domain 表达式规则 最简单的格式:[('字段名','操作符',值)] 例: ...
- codevs 1296 营业额统计 (splay 点操作)
题目大意 每次加入一个值,并且询问之前加入的数中与该数相差最小的值. 答案输出所有相差值的总和. 解题分析 = = 参考程序 #include <bits/stdc++.h> using ...
- 使用AtomicInteger原子类代替i++线程安全操作
Java中自增自减操作不具原子性,在多线程环境下是线程不安全的,可以使用使用AtomicInteger原子类代替i++,i--操作完成多线程线程安全操作. 下面是等于i++多线程的自增操作代码: pu ...
- Java发送带附件的QQ邮箱
由于腾讯公司给QQ邮箱增加了一个授权码的密码保护,导致之前网上很多代码都不能用,于是就自己敲了一份demo. 注意在密码那里可能需要授权码,具体设置:http://service.mail.qq.co ...
- BZOJ(2) 1041: [HAOI2008]圆上的整点
1041: [HAOI2008]圆上的整点 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4966 Solved: 2258[Submit][Sta ...