SQL记录-PLSQL事务
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命令的一般语法是:
- COMMIT;
示例,
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (2, 'Khilan', 25, 'Delhi', 1500.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (3, 'kaushik', 23, 'Kota', 2000.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (4, 'Chaitali', 25, 'Mumbai', 6500.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (5, 'Hardik', 27, 'Bhopal', 8500.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (6, 'Komal', 22, 'MP', 4500.00 );
- COMMIT;
回滚事务
对数据库所做的不提交更改可以使用ROLLBACK命令撤消。
ROLLBACK命令的一般语法是:
- ROLLBACK [TO SAVEPOINT < saveyiibai_name>];
当一个事务因一些前所未有的情况中止,如系统故障,则整个事务由于提交自动回滚。如果不使用保存点,然后简单地使用下面的语句来回滚所有的变化:
- ROLLBACK;
保存点
保存点是某种标志,帮助分裂一个长事务分成更小的单位设置了一些检查点。由一个长事务中设置保存点,可以根据需要回滚到一个检查点。这是通过发出SAVEPOINT命令来完成。
保存点命令的一般语法是:
- SAVEPOINT < saveyiibai_name >;
示例:
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (7, 'Rajnish', 27, 'HP', 9500.00 );
- INSERT INTO CUSTOMERS (ID,NAME,AGE,ADDRESS,SALARY)
- VALUES (8, 'Riddhi', 21, 'WB', 4500.00 );
- SAVEPOINT sav1;
- UPDATE CUSTOMERS
- SET SALARY = SALARY + 1000;
- ROLLBACK TO sav1;
- UPDATE CUSTOMERS
- SET SALARY = SALARY + 1000
- WHERE ID = 7;
- UPDATE CUSTOMERS
- SET SALARY = SALARY + 1000
- WHERE ID = 8;
- COMMIT;
在这里,ROLLBACK TO sav1; 声明回滚变化到一点,在那里标志着保存点sav1,之后将开始新的变化。
自动事务控制
要执行一个自动COMMIT在每一个INSERT,UPDATE或DELETE命令执行时,可以设置AUTOCOMMIT环境变量:
- SET AUTOCOMMIT ON;
可以关闭使用以下命令自动提交模式:
- SET AUTOCOMMIT OFF;
SQL记录-PLSQL事务的更多相关文章
- SQL记录-PLSQL记录
PL/SQL记录 PL/SQL记录就是可以容纳不同类型的数据项的数据结构.记录由不同字段,类似于数据库表的行. 例如,要保留跟踪图书馆中的书籍.可能要跟踪有关每本书下面的属性类似:标题,作者,主题 ...
- SQL记录-PLSQL基本语法与数据类型
PL/SQL基本语法 PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成: S.N. 段和说明 1 声明 此部分开头使用关键字DECLARE.它是一 ...
- SQL记录-PLSQL游标
PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...
- SQL记录-PLSQL条件控制
PL/SQL条件控制 决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...
- SQL记录-PLSQL变量与常量文字
PL/SQL变量 变量是只不过是一个给定的存储区域,程序可以操纵的名称.PL/SQL每个变量具有一个特定的数据类型,它决定了大小和变量的存储器的值,可以说存储器和设置操作可以施加到可变内被存储的范 ...
- SQL记录-PLSQL包
PL/SQL包 PL/SQL包是组逻辑相关的PL/SQL类型,变量和子程序模式对象. 程序包将有两个强制性的部分: 包装规范定义 包体或定义 包装规范定义 规范是接口到包.它只是声明的类型,变量,常量 ...
- SQL记录-PLSQL触发器
PL/SQL触发器 触发器是存储程序,它会自动执行或发射当一些事件发生.触发器,事实上,写入响应于以下任一事件将被执行: 数据库操作(DML)语句(DELETE,INSERT,UPDATE或) 数据库 ...
- SQL记录-PLSQL函数
PL/SQL函数 PL/SQL函数与过程相同,不同之处在于函数有一个返回值.因此,前面的章节中的所有讨论都适用于函数. 创建函数 建立一个独立函数可以使用CREATE FUNCTION语句创建.CRE ...
- SQL记录-PLSQL过程
PL/SQL过程 子程序是一个程序单元/模块执行特定的任务.这些子程序被组合以形成更大的程序.这基本上是被称为“模块化设计”.子程序可以调用由另一个子程序或程序被称为调用程序. 子程序可以创建: ...
随机推荐
- Asp.Net_序列化、反序列化
.net序列化及反序列化 在我们深入探讨C#序列化和反序列化之前我们先要明白什么是序列化,它又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.序列化就是把一个对象保存到一个文件或数据库 ...
- CMake与MSVC工程化实践
CMake与MSVC工程化实践 CMake基础 cmake无疑是最流行的c++跨平台构建工具之一,关于cmake入门指南这里不再赘述,官方文档是最好的参考,这里通过一个例子简述构建一个工程常用的函数和 ...
- Nmap命令
命令行:(显示扫描过程 -v ) 扫描单个主机 #nmap www.hostName.com 扫描整个ip段(子网) #nmap 192.168.1.1/24 //表示当前ip下的24位掩码主机都要扫 ...
- Linux内核分析——第六周学习笔记
进程的描述和进程的创建 前言:以下笔记除了一些讲解视频中的概念记录,图示.图示中的补充文字.总结.分析.小结部分均是个人理解.如有错误观点,请多指教! PS.实验操作会在提交到MOOC网站的博客中写.
- C#(近期目标)
最近很多同学为了实习都在学Java,但是我个人更偏好C#,首先因为自己基础不是太好,而C#又更容易入门,拥有比较完善的开发环境,是微软开发出来的语言.它吸收了C++和Java两门语言的所有有点,因为它 ...
- springmvc关于redisCluster的使用及配置
首先附上maven仓库jar包的下载地址:https://repo.spring.io/webapp/#/artifacts/browse/tree/General/libs-release-loca ...
- Js单元测试工具 以及 粗浅的对我的快乐运算进行测试
1. Karma的介绍 Karma是Testacular的新名字,在2012年google开源了Testacular,2013年Testacular改名为Karma.Karma是一个让人感到非常神秘的 ...
- 使用Java语言递归删除目录下面产生的临时文件
背景:项目copy的过程中,在项目的目录文件夹下面都产生了一个固定的文件,很是讨厌.手动删除的话比较费力,所以写了一个简单的Java程序去删除: public static void main(Str ...
- Ubutnu linux 下升级python版本,以2.x升级到3.x为例
Linux操作系统一般 都会自带python,但是python版本会比主流低,故升级python, 主要思路:自带的python的链接link文件是在/usr/bin 下,采用sudo apt-get ...
- 【题解】 [ZJOI2008] 泡泡堂(贪心/二分图/动态规划)
懒得复制,戳我戳我 Solution: 就是有一个贪心策略:(以下假设使\(A\)队分数更高) \(First:\)比较两个分值的最小值,如果\(A\)最小分比\(B\)最小分大就直接比较两个最小的, ...