加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQLServer事务的傻瓜讲解

发布时间:2020-12-12 14:37:21 所属栏目:MsSql教程 来源:网络整理
导读:在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。 ?第一:我们先创建一个临时表,填写一些数据。 ? CREATE TABLE #tab (id INT,country NVARCHAR(10),popu INT )INSERT INTO

在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。

?第一:我们先创建一个临时表,填写一些数据。

?

CREATE TABLE #tab (id INT,country NVARCHAR(10),popu INT )
INSERT INTO #tab VALUES (1,'中国','600')
INSERT INTO #tab VALUES (2,'美国','100')
INSERT INTO #tab VALUES (3,'加拿大','100')
INSERT INTO #tab VALUES (4,'英国','200')
INSERT INTO #tab VALUES (5,'法国','300')
INSERT INTO #tab VALUES (6,'日本','250')
INSERT INTO #tab VALUES (7,'德国','200')
INSERT INTO #tab VALUES (8,'墨西哥','50')
INSERT INTO #tab VALUES (9,'印度','250')

以上我们就得到了一个临时表数据。

第二: 写几句常用事务语句。


BEGIN TRANSACTION  
COMMIT  
ROLLBACK

好需要的数据和语句我们准备好了。 仔细看下面操作:

-- 我们下执行一下SQL 开始事务
BEGIN TRANSACTION
然后我们直接删除#tab

DELETE FROM #tab
现在肯定查询不到数据了。

?

现在我们是执行了事务之后删除的#tab( 一定要先执行事务,不然你就会把数据直接给KO掉了。)

注 : 假如我们上一步我们执行错误,需要回复数据。我们需要执行一下


--回滚
ROLLBACK

我们的数据又回来了。

?

注 : 假如上一步我们执行正确了, 你也不要忘记执行下面这句 (这句不执行的话会造成用户死锁。)


-- 执行
COMMIT

理解很简单吧。事务就是 先执行BEGIN TRANSACTION?? 错误执行 ROLLBACK? 正确执行 COMMIT?? 所以我们会经常用到这种格式的事务。

BEGIN TRANSACTION??? -- 开始事务
BEGIN TRY? -- 捕捉异常
???????? DELETE FROM #tab
???????? COMMIT? -- 无异常执行
END TRY
BEGIN CATCH
???????? ROLLBACK? -- 发现异常 回滚
END CATCH

?

事务的机制很复杂,但在使用时我们只需要理解上面的顺序即可。 由此我们可以进行程序细颗粒事务回滚的分析,在需要的地方正确的使用事务。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读