1.条件控制

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. 顺序控制

A.GOTO语句:用于跳转到指定<<标号>>去执行语句。

缺点是会增加程序的复杂性,降低可读性,所以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中更改数据和管理事务的更多相关文章

  1. 使用Hive或Impala执行SQL语句,对存储在HBase中的数据操作

    CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...

  2. 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作(二)

    CSSDesk body { background-color: #2574b0; } /*! zybuluo */ article,aside,details,figcaption,figure,f ...

  3. 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据操作

    http://www.cnblogs.com/wgp13x/p/4934521.html 内容一样,样式好的版本. 使用Hive或Impala执行SQL语句,对存储在Elasticsearch中的数据 ...

  4. sql语句 怎么从一张表中查询数据插入到另一张表中?

    sql语句 怎么从一张表中查询数据插入到另一张表中?  ----原文地址:http://www.phpfans.net/ask/MTc0MTQ4Mw.html 比如我有两张表 table1 字段 un ...

  5. 程序一 用记事本建立文件src.dat,其中存放若干字符。编写程序,从文件src.dat中读取数据,统计其中的大写字母、小写字母、数字、其它字符的个数,并将这些数据写入到文件test.dat中。

    用记事本建立文件src.dat,其中存放若干字符.编写程序,从文件src.dat中读取数据,统计其中的大写字母.小写字母.数字.其它字符的个数,并将这些数据写入到文件test.dat中. #inclu ...

  6. sql存储过程通过ID删除两表中的数据。

    CREATE OR REPLACE PROCEDURE del_p --建立名为del_p 的过程 IS CURSOR get_abid --简历名为get_abid的cursor 用来存放a表的id ...

  7. Oracle数据库之PL/SQL程序设计基础

    PL/SQL程序设计基础 一.PL/SQL块结构 前边我们已经介绍了PL/SQL块的结构,再来回顾一下: DECLARE /* * 声明部分——定义常量.变量.复杂数据类型.游标.用户自定义异常 */ ...

  8. JDBC基础:JDBC快速入门,JDBC工具类,SQL注入攻击,JDBC管理事务

    JDBC基础 重难点梳理 一.JDBC快速入门 1.jdbc的概念 JDBC(Java DataBase Connectivity:java数据库连接)是一种用于执行SQL语句的Java API,可以 ...

  9. 二十五、oracle pl/sql进阶--控制结构(分支,循环,控制)

    一.pl/sql的进阶--控制结构在任何计算机语言(c,java,pascal)都有各种控制语句(条件语句,循环结构,顺序控制结构...),在pl/sql中也存在这样的控制结构.在本部分学习完成后,希 ...

随机推荐

  1. Linux的net.ipv4.tcp_timestamps参数

    Q1 今天发生了一个奇怪的现象,在家里始终打开公司的网站打开不了,我就齐了怪了,然后我就各种测试,从ping到dig域名,然后再curl,都是没有问题的,但是就是打不开,最好没有办法只能抓包了,从抓包 ...

  2. db2构建临时结果集

    一 values  ('1',2,3)   为一行   ‘1’   2    3   行数据类型可以不同  values  ('1',2,3),('f',5,6) 为两行 (values  1,2,3 ...

  3. cmd杀死进程

    打开cmd 1.查看所有进程占用的端口 输入:netstat –ano(查看所有进程,查找相应占用端口的程序的pid) 直接查看占用指定端口的程序的pid 输入:netstat -ano|findst ...

  4. 第七节:web爬虫之urllib(三)

    第二个模块 error : 即异常处理模块,如果出现请求错误,我们可以捕获这些异常,然后进行重试或其他操作保证程序不会意外终止.

  5. Windows Server 2008R2服务器IIS安装步骤

    注意点: 添加ASP.NET ..NET 扩展性.CGI.ISAPI 扩展.ISAPI 筛选器,去掉 目录浏览(因为大多数网站用不到.) 如果需要用到asp则勾选asp,如果需要用shtm需要开启在服 ...

  6. 线程 synchronized锁机制

    脏读 一个常见的概念.在多线程中,难免会出现在多个线程中对同一个对象的实例变量进行并发访问的情况,如果不做正确的同步处理,那么产生的后果就是"脏读",也就是取到的数据其实是被更改过 ...

  7. LightOJ 1348 Aladdin and the Return Journey

    Aladdin and the Return Journey Time Limit: 2000ms Memory Limit: 32768KB This problem will be judged ...

  8. MVC系统学习1—MVC执行流程

    用MVC来做开发也有一段时间了,但是感觉一直没入门,就徘徊在似懂非懂的层次,和去年刚毕业学习WebForm时一样,当时通过张子阳老兄的几篇文章,明白了请求处理流程,页面生命周期才真正明白了WebFor ...

  9. tyvj1117 拯救ice-cream

      背景 天好热……Tina顶着那炎炎的烈日,向Ice-cream home走去……可是……停电了……冰淇淋们躺在Ice-cream home的冰柜里,慢慢地……慢慢地……融化…………你说,她能赶在冰 ...

  10. nyoj_600_花儿朵朵_201404162000

    花儿朵朵 时间限制:1000 ms  |  内存限制:65535 KB 难度:5   描述 春天到了,花儿朵朵盛开,hrdv是一座大花园的主人,在他的花园里种着许多种鲜花,每当这个时候,就会有一大群游 ...