SQLServer数据库之SQL必知必会—管理事务处理
小标 2019-05-24 来源 : 阅读 2331 评论 0

摘要:本文主要向大家介绍了SQLServer数据库之SQL必知必会—管理事务处理,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助。

本文主要向大家介绍了SQLServer数据库之SQL必知必会—管理事务处理,通过具体的内容向大家展现,希望对大家学习SQLServer数据库有所帮助。

SQLServer数据库之SQL必知必会—管理事务处理

1.事务处理

使用事务处理,通过确保成批的SQL操作要么完全执行,要么完全不执行,来维护数据库的完整性。

下面时关于事务处理需要知道的几个术语:

  • 事务(transaction)指一组SQL语句;

  • 回退(rollback)指撤销指定SQL语句的过程;

  • 提交(commit)指将未存储的SQL语句结果写入数据库表;

  • 保留点(savepoint)指事务处理中设置的临时占位符(placeholder),可以对它分布回退(与回退整个事务处理不同)。

提示:可以回退哪些语句?
事务处理用来管理INSERT、UPDATE和DELETE语句。不能回退SELECT语句(回退SELECT语句也没有必要),也不能回退CREATE或DROP操作。事务处理可以使用这些语句,但进行回退时,这些操作也不撤销。

2.控制事务处理

管理事务的关键在于将SQL语句组分解为逻辑块,并明确规定数据何时进行回退,何时不应该回退。

BEGIN TRANSACTION...COMMIT TRANSACTION

-- 或者
START TRANSACTION...-- 或者
SET TRANSACTION...-- 或者
BEGIN...

通常,COMMIT用于保存更改,ROLLBACK用于撤销。

3.使用ROLLBACK

DELETE FROM Orders;ROLLBACK;

4.使用COMMIT

一般的SQL语句都是针对数据库表直接执行和编写的。这就是所谓的隐式提交,即提交(写或保存)操作都是自动进行的。

在事务处理块中,提交不会隐式进行。不过,不同DBMS的做法有所不同。有的DBMS按隐式提交处理事务端,有的则不这样。

进行明确的提交,使用COMMIT语句。

BEGIN TRANSACTIONDELETE OrderItems WHERE order_num = 12345DELETE Orders WHERE order_num = 12345COMMIT TRANSACTION

5.使用保留点

使用简单的ROLLBACK和COMMIT语句,就可以写入或撤销整个事务。但是,只对简单的事务才能这样做,复杂的事务可能需要部分提交或回退。

要支持回退部分事务,必须在事务处理块中的合适位置放置占位符。这样,如果需要回退,可以回退到某个占位符。

在SQL中,执行占位符称为保留点。在MariaDB、MySQL和Oracle中创建占位符,可使用SAVEPOINT语句。

-- MariaDB、MySQL、OracleSAVEPOINT delete1;

-- SQL ServeSAVE TRANSACTION delete1;

要回退到本例给出的保留点,在SQL中可如下进行:

ROLLBACK TRANSACTION delete1;

在MariaDB、MySQL、Oracle中,如下进行:

ROLLBACK TO delete1;

下面时应该完整的SQL Serve例子:

BEGIN TRANSACTION
INSERT INTO Customers(cust_id, cust_name)VALUES('10000010', 'Toy Emporium');
SAVE TRANSACTION StartOrder;
INSERT INTO Orders(order_num, order)_date, cust_id)VALUES(20100, '2001/12/1', '10000010')IF @@ERROR <> ROLLBACK TRANSACTION StartOrder;INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)VALUES(20100,1,'BRO1',100,5.49);
IF @@ERROR <> ROLLBACK TRANSACTION StartOrder;INSERT INTO OrderItems(order_num, order_item, prod_id, quantity, item_price)VALUES(20100,2,'BR03',100,10.99);
IF @@ERROR <> ROLLBACK TRANSACTION StartOrder;COMMIT TRANSACTION

在第一条INSERT语句之后定义了一个保留点,因此,如果后面的任何一个INSERT操作失败,事务处理最近回退到这里。在SQL Serve中,可检查一个名为@@ERROR的变量,看操作是否成功。(其他DBMS使用不同的函数或变量返回此信息。)如果@@ERROR返回一个非0的值,表示有错误发生,事务处理回退到保留点。如果整个事务处理成功,发布COMMIT以保留数据。

提示:保留点越多越好
可以在SQL代码中设置任意多的保留点,越多越好。为什么呢?因为保留点越多,你就越能灵活地进行回退。


本文由职坐标整理并发布,希望对同学们学习SQL Server有所帮助,更多内容请关注职坐标数据库SQL Server数据库频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程