PL/SQL事务

 

数据库事务是一个工作的原子单元,其可以由一个或多个相关的SQL语句组成。所谓的原子性就是数据库的修改所带来的构成事务的SQL语句可以集体被提交,即永久到数据库或从数据库中(撤消)回滚。

一个成功执行的SQL语句和提交的事务不一样。即使一个SQL语句执行成功,除非包含该语句的事务被提交,但也可以回滚和声明(S)的所有更改可以撤消。

开始/结束事务

事务都有开始和结束。事务开始时有下列事件之一:

  • 连接到数据库后执行的第一个SQL语句。

  • 在事务完成之后发出每一个新的SQL语句完成。

事务结束时的下列事件之一发生:

  • COMMIT或发出ROLLBACK语句。

  • DDL语句,如CREATE TABLE语句,则发出;因为在这种情况下,COMMIT被自动执行。

  • 一个DCL语句,比如一个GRANT语句发出; 因为在这种情况下,COMMIT被自动执行。

  • 用户从数据库断开。

  • 从SQL* PLUS用户退出通过发出EXIT指令,COMMIT自动执行。

  • SQL* Plus异常终止,自动执行ROLLBACK。

  • 一个DML语句失败; 在这种情况下自动执行撤消DML语句ROLLBACK。

提交事务

事务是通过发出SQL命令COMMIT永久生效。COMMIT命令的一般语法是:

  1. COMMIT;

示例,

  1. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  2. VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );
  3. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  4. VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );
  5. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  6. VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
  7. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  8. VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 );
  9. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  10. VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );
  11. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  12. VALUES (6, 'Komal', 22, 'MP', 4500.00 );
  13. COMMIT;

回滚事务

对数据库所做的不提交更改可以使用ROLLBACK命令撤消。

ROLLBACK命令的一般语法是:

  1. ROLLBACK [TO SAVEPOINT < saveyiibai_name>];

当一个事务因一些前所未有的情况中止,如系统故障,则整个事务由于提交自动回滚。如果不使用保存点,然后简单地使用下面的语句来回滚所有的变化:

  1. ROLLBACK;

保存点

保存点是某种标志,帮助分裂一个长事务分成更小的单位设置了一些检查点。由一个长事务中设置保存点,可以根据需要回滚到一个检查点。这是通过发出SAVEPOINT命令来完成。

保存点命令的一般语法是:

  1. SAVEPOINT < saveyiibai_name >;

示例:

  1. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  2. VALUES (7, 'Rajnish', 27, 'HP', 9500.00 );
  3. INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
  4. VALUES (8, 'Riddhi', 21, 'WB', 4500.00 );
  5. SAVEPOINT sav1;
  6.  
  7. UPDATE CUSTOMERS
  8. SET SALARY = SALARY + 1000;
  9. ROLLBACK TO sav1;
  10.  
  11. UPDATE CUSTOMERS
  12. SET SALARY = SALARY + 1000
  13. WHERE ID = 7;
  14. UPDATE CUSTOMERS
  15. SET SALARY = SALARY + 1000
  16. WHERE ID = 8;
  17. COMMIT;

在这里,ROLLBACK TO sav1; 声明回滚变化到一点,在那里标志着保存点sav1,之后将开始新的变化。

自动事务控制

要执行一个自动COMMIT在每一个INSERT,UPDATE或DELETE命令执行时,可以设置AUTOCOMMIT环境变量:

  1. SET AUTOCOMMIT ON;

可以关闭使用以下命令自动提交模式:

  1. SET AUTOCOMMIT OFF;

SQL记录-PLSQL事务的更多相关文章

  1. SQL记录-PLSQL记录

    PL/SQL记录   PL/SQL记录就是可以容纳不同类型的数据项的数据结构.记录由不同字段,类似于数据库表的行. 例如,要保留跟踪图书馆中的书籍.可能要跟踪有关每本书下面的属性类似:标题,作者,主题 ...

  2. SQL记录-PLSQL基本语法与数据类型

    PL/SQL基本语法 PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成: S.N. 段和说明 1 声明 此部分开头使用关键字DECLARE.它是一 ...

  3. SQL记录-PLSQL游标

    PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...

  4. SQL记录-PLSQL条件控制

    PL/SQL条件控制   决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...

  5. SQL记录-PLSQL变量与常量文字

    PL/SQL变量   变量是只不过是一个给定的存储区域,程序可以操纵的名称.PL/SQL每个变量具有一个特定的数据类型,它决定了大小和变量的存储器的值,可以说存储器和设置操作可以施加到可变内被存储的范 ...

  6. SQL记录-PLSQL包

    PL/SQL包 PL/SQL包是组逻辑相关的PL/SQL类型,变量和子程序模式对象. 程序包将有两个强制性的部分: 包装规范定义 包体或定义 包装规范定义 规范是接口到包.它只是声明的类型,变量,常量 ...

  7. SQL记录-PLSQL触发器

    PL/SQL触发器 触发器是存储程序,它会自动执行或发射当一些事件发生.触发器,事实上,写入响应于以下任一事件将被执行: 数据库操作(DML)语句(DELETE,INSERT,UPDATE或) 数据库 ...

  8. SQL记录-PLSQL函数

    PL/SQL函数 PL/SQL函数与过程相同,不同之处在于函数有一个返回值.因此,前面的章节中的所有讨论都适用于函数. 创建函数 建立一个独立函数可以使用CREATE FUNCTION语句创建.CRE ...

  9. SQL记录-PLSQL过程

    PL/SQL过程   子程序是一个程序单元/模块执行特定的任务.这些子程序被组合以形成更大的程序.这基本上是被称为“模块化设计”.子程序可以调用由另一个子程序或程序被称为调用程序. 子程序可以创建: ...

随机推荐

  1. Asp.Net_序列化、反序列化

    .net序列化及反序列化 在我们深入探讨C#序列化和反序列化之前我们先要明白什么是序列化,它又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.序列化就是把一个对象保存到一个文件或数据库 ...

  2. CMake与MSVC工程化实践

    CMake与MSVC工程化实践 CMake基础 cmake无疑是最流行的c++跨平台构建工具之一,关于cmake入门指南这里不再赘述,官方文档是最好的参考,这里通过一个例子简述构建一个工程常用的函数和 ...

  3. Nmap命令

    命令行:(显示扫描过程 -v ) 扫描单个主机 #nmap www.hostName.com 扫描整个ip段(子网) #nmap 192.168.1.1/24 //表示当前ip下的24位掩码主机都要扫 ...

  4. Linux内核分析——第六周学习笔记

    进程的描述和进程的创建 前言:以下笔记除了一些讲解视频中的概念记录,图示.图示中的补充文字.总结.分析.小结部分均是个人理解.如有错误观点,请多指教! PS.实验操作会在提交到MOOC网站的博客中写.

  5. C#(近期目标)

    最近很多同学为了实习都在学Java,但是我个人更偏好C#,首先因为自己基础不是太好,而C#又更容易入门,拥有比较完善的开发环境,是微软开发出来的语言.它吸收了C++和Java两门语言的所有有点,因为它 ...

  6. springmvc关于redisCluster的使用及配置

    首先附上maven仓库jar包的下载地址:https://repo.spring.io/webapp/#/artifacts/browse/tree/General/libs-release-loca ...

  7. Js单元测试工具 以及 粗浅的对我的快乐运算进行测试

    1. Karma的介绍 Karma是Testacular的新名字,在2012年google开源了Testacular,2013年Testacular改名为Karma.Karma是一个让人感到非常神秘的 ...

  8. 使用Java语言递归删除目录下面产生的临时文件

    背景:项目copy的过程中,在项目的目录文件夹下面都产生了一个固定的文件,很是讨厌.手动删除的话比较费力,所以写了一个简单的Java程序去删除: public static void main(Str ...

  9. Ubutnu linux 下升级python版本,以2.x升级到3.x为例

    Linux操作系统一般 都会自带python,但是python版本会比主流低,故升级python, 主要思路:自带的python的链接link文件是在/usr/bin 下,采用sudo apt-get ...

  10. 【题解】 [ZJOI2008] 泡泡堂(贪心/二分图/动态规划)

    懒得复制,戳我戳我 Solution: 就是有一个贪心策略:(以下假设使\(A\)队分数更高) \(First:\)比较两个分值的最小值,如果\(A\)最小分比\(B\)最小分大就直接比较两个最小的, ...