zoukankan      html  css  js  c++  java
  • SQL SERVER 事务的使用(tran)

    https://www.cnblogs.com/itsone/p/10273317.html

    C# 事务里面如果只是针对单数据库,则可以使用SqlTransaction,跨数据库使用TransactionScope。

    sql server事务的使用是为了确保数据的一致性。

    通常写法

    begin tran
    --sql 语句1
    --sql 语句2
    --sql 语句3
    commit tran

    上面写法存在隐患,当操作(增删改)是由null引发的错误时,事务会跳过错误继续执行正常的语句。例如:

    复制代码
    --创建表Student
    create table Student(Name nvarchar(20) not null)
    --建立事务
    begin tran
    inserted into Student(Name) values (null)
    inserted into Student(Name) values ('小札')
    inserted into Student(Name) values (null)
    commit tran
    --由null引发的错误,insert,delete,update都会跳过错误继续执行
    复制代码

    上面结果会多一条数据为“小札”。为了避免了这样的问题:

    有三种方法:其中@@error,@@trancount是全局变量,只要发生错误,@@error不等于0,只要执行一次事务,@@trancount就+1,回滚会变为0。

    【方法一】:xact_abort on/off  on:开启,事务一旦出问题,全部回滚  off:关闭,不检查事务是否发生错误。

    set xact_abort on
    begin tran
    --sql语句1
    --sql语句2
    --sql语句3
    commit

    【方法二】:每条操作语句后面判断是否回滚。

    复制代码
    begin tran
    --sql语句1
    if @@error<>0
     begin
       rollback tran
       return --这里除了return跳出,也可以使用goto+标签跳出事务
     end
    --sql语句2
    if @@error<>0
     begin
       rollback tran
       return
     end
    commit tran
    复制代码

    【方法三】:try  catch

    复制代码
    begin tran
     begin try
        --sql语句1
        --sql语句2
        --sql语句3
     end try
     begin catch
        if @@trancount>0
            rollback tran
     end catch
     if @@trancount>0
        commit tran
    复制代码
  • 相关阅读:
    查询论文引用次数及格式和相似论文的方法
    JAVA日期加减运算
    luogu2833 等式
    luogu2261 [CQOI2007] 余数之和
    luogu2822 组合数问题
    luogu3942 将军令 贪心
    luogu3941 入阵曲
    luogu3939 数颜色
    二分查找总结
    luogu3938 斐波那契
  • 原文地址:https://www.cnblogs.com/yyzyou/p/14429952.html
Copyright © 2011-2022 走看看