zuandilong

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

    

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

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

 

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

分类:

技术点:

相关文章:

  • 2021-09-29
  • 2021-11-17
  • 2021-05-30
  • 2021-12-29
  • 2021-12-29
  • 2021-12-29
  • 2021-12-29
猜你喜欢
  • 2021-12-16
  • 2021-12-13
  • 2021-06-09
  • 2021-10-15
相关资源
相似解决方案