SQLServer事务的傻瓜讲解

来源:未知 责任编辑:责任编辑 发表时间:2013-12-06 08:45 点击:

SQLServer事务的傻瓜讲解
 
在本文之前我读过多篇关于事务的文章,大都说的比较深奥,可能让新手也难以理解。 在此我们用非常简单的例子讲解一下事务的应用吧。
    
 第一:我们先创建一个临时表,填写一些数据。
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')
以上我们就得到了一个临时表数据。

 
www.2cto.com  
 
第二: 写几句常用事务语句。
BEGIN TRANSACTION  
COMMIT  
ROLLBACK
 
好需要的数据和语句我们准备好了。 仔细看下面操作:
-- 我们下执行一下SQL 开始事务
BEGIN TRANSACTION
然后我们直接删除#tab
DELETE FROM #tab
现在肯定查询不到数据了。


 
现在我们是执行了事务之后删除的#tab( 一定要先执行事务,不然你就会把数据直接给KO掉了。)
注 : 假如我们上一步我们执行错误,需要回复数据。我们需要执行一下
--回滚
ROLLBACK
我们的数据又回来了。


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


理解很简单吧。事务就是 先执行BEGIN TRANSACTION   错误执行 ROLLBACK  正确执行 COMMIT   所以我们会经常用到这种格式的事务。
 
BEGIN TRANSACTION    -- 开始事务
BEGIN TRY  -- 捕捉异常
         DELETE FROM #tab
         COMMIT  -- 无异常执行
END TRY
BEGIN CATCH
         ROLLBACK  -- 发现异常 回滚
END CATCH
 
事务的机制很复杂,但在使用时我们只需要理解上面的顺序即可。 由此我们可以进行程序细颗粒事务回滚的分析,在需要的地方正确的使用事务。
 
 
 
作者 _大师兄_
    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • sql常见面试题
    • SQL SERVER 2005性能之跟踪
    • SQL编程(一)
    • LINUX上RMAN自动备份脚本
    • sql server面试题
    • 如何将多个SQL查询统计结果一次显示出来
    • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
    • sql server 列转行
    • SQL小技巧系列 --- 行转列合并
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1