第二十课 管理事务处理
来源:互联网 发布:北京新华电脑学校java 编辑:程序博客网 时间:2024/05/21 19:49
第二十课 管理事务处理
预习与回顾:
第十九课介绍了什么是存储过程,为什么使用存储过程,以及介绍了执行和创建存储过程的语法,使用存储过程的一些方法;第二十课将学习什么是事务处理,如何利用COMMIT和ROLLBACK语句管理事务处理。
20.1、事务处理
使用事务处理(transaction processing),通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。
事务处理是一种机制,用来管理必须成批执行的SQL操作,保证数据库不包含不完整的操作结果。利用事务处理,可以保证一组操作不会中途停止,它们要么完全执行,要么完全不执行(除非明确指示)。如果没有错误发生,整组语句提交给(写到)数据库表;如果发生错误,则进行回退(撤销),将数据库恢复到某个已知且安全的状态。
几个术语:
事务(transaction)指一组SQL语句;
回退(rollback)指撤销指定SQL语句的过程;
提交(commit)指将未存储的SQL语句结果写入数据库表;
保留点(savepoint)指事务处理中设置的临时占位符(placeholder),可以对它发布回退(与回退整个事务处理不同)。
!!回退哪些语句?:事务处理用来管理INSERT、UPDATE和DELETE语句。不能回退SELECT语句(回退SELECT语句也没有必要),也不能回退CREATE或DROP操作。事务处理中可以使用这些语句,但进行回退时,这些操作也不撤销。!!
20.2、控制事物处理
管理事务的关键在于将SQL语句组分解为逻辑块,并明确规定数据何时应该回退,何时不应该回退。
SQLServer中,标识如下:
输入▼
BEGIN TRANSACTION
...
COMMIT TRANSACTION
分析▼在这个例子中,BEGIN TRANSACTION和COMMIT TRANSACTION语句之间的SQL必须完全执行或者完全不执行。
20.2.1、使用ROLLBACK
SQL的ROLLBACK命令用来回退(撤销)SQL语句,请看下面的语句:
输入▼
DELETE FROM Orders;
ROLLBACK;
分析▼在此例子中,执行DELETE操作,然后用ROLLBACK语句撤销。虽然这不是最有用的例子,但它的确能够说明,在事务处理块中,DELETE操作(与INSERT和UPDATE操作一样)并不是最终的结果。
20.2.2、使用COMMIT
一般的SQL语句都是针对数据库表直接执行和编写的。这就是所谓的隐式提交(implicitcommit),即提交(写或保存)操作是自动进行的。
在事务处理块中,提交不会隐式进行。进行明确的提交,使用COMMIT语句。
一个SQL Server的例子:
输入▼
BEGIN TRANSACTION
DELETE OrderItems
WHEREorder_num = 12345
DELETE Orders
WHEREorder_num = 12345
COMMIT TRANSACTION
分析▼在这个SQL Server例子中,从系统中完全删除订单12345。因为涉及更新两个数据库表Orders和OrderItems,所以使用事务处理块来保证订单不被部分删除。最后的COMMIT语句仅在不出错时写出更改。如果第一条DELETE起作用,但第二条失败,则DELETE不会提交。
20.2.3、使用保留点
要支持回退部分事务,必须在事务处理块中的合适位置放置占位符。这样,如果需要回退,可以回退到某个占位符。在SQL中,这些占位符称为保留点。
在SQL Server中,如下进行:
输入▼
SAVE TRANSACTION delete1;
---每个保留点都要取能够标识它的唯一名字,以便在回退时,DBMS知道回退到何处。要回退到本例给出的保留点,
在SQL Server中可如下进行:
输入▼
ROLLBACK TRANSACTION delete1;
一个完整的SQL Server例子:
输入▼
BEGIN TRANSACTION
INSERT INTO Customers(cust_id, cust_name)
VALUES('1000000010',
'Toys Emporium');
SAVE TRANSACTION StartOrder;
INSERT INTO Orders(order_num, order_date, cust_id)
VALUES(20100,'2001/12/1','1000000010');
IF @@ERROR <> 0 ROLLBACKTRANSACTION StartOrder;
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20100, 1,'BR01', 100, 5.49);
IF @@ERROR <> 0 ROLLBACKTRANSACTION StartOrder;
INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)
VALUES(20100, 2,'BR03', 100, 10.99);
IF @@ERROR <> 0 ROLLBACKTRANSACTION StartOrder;
COMMIT TRANSACTION
分析▼这里的事务处理块中包含了4条INSERT语句。在第一条INSERT语句之后定义了一个保留点,因此,如果后面的任何一个INSERT操作失败,事务处理最近回退到这里。在SQL Server中,可检查一个名为@@ERROR的变量,看操作是否成功。(其他DBMS使用不同的函数或变量返回此信息。)如果@@ERROR返回一个非0的值,表示有错误发生,事务处理回退到保留点。如果整个事务处理成功,发布COMMIT以保留数据。
提示:保留点越多越好
可以在SQL代码中设置任意多的保留点,越多越好。为什么呢?因为保留点越多,你就越能灵活地进行回退
- 第二十课 管理事务处理
- SQL必知必会 笔记 第二十章 管理事务处理
- 第二十章 函式库管理
- 第二十章、Linux进程管理
- 第二十章 事务的概念与JDBC事务处理
- 关于mysql管理事务处理
- 26 管理事务处理
- hibernate_事务处理、session管理
- 第二十课(续)
- 孙鑫 第二十课HOOK
- 第二十课 字符串库
- 第二十
- 第二十章 Tarball 的管理与建议
- 韩语学习之第二十课
- 第二十一次课课后作业
- Mysql必知必会(笔记)【管理事务处理】
- 读书笔记--SQL必知必会20--管理事务处理
- 第二十章、启动流程、模块管理与 Loader
- 计算单词数
- Windows7 创建右键发送到桌面的快捷方式
- 处理百万级以上的数据提高查询速度的方法。
- 从尾到头打印链表 【C++实现】
- hdu5972 Regular Number (bitset应用+快速匹配+shiftAnd匹配算法学习模板)
- 第二十课 管理事务处理
- 数字全排列
- mysql安装教程
- Linux下C++的编程几个重要的工具和概念
- 由CSS浮动、定位引发的对CSS标准流的思考
- 【数据结构】树与二叉树 基础要点+二叉树 Python 实现
- Java环境变量的配置
- ZooKeeper分布式安装与配置
- Truck History( poj 1789 prim)