当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 全接触sqlserver异常与孤立事务

MSSQL
如何用SQL语句来判断已知表是否存在
剖析SQL Server 2005中的报告服务架构
使用Microsoft SQL Server 2000的XML查询
让SQL Server为工作负载高峰提前准备
用Sql server一次插入多条数据
SQL SERVER2000深入学习之常见错误
关于SQL Server数据库的若干注意事项
sql server 2005中的表分区
SQL Server实用经验与技巧大汇集
限制SQL Server只能让指定的机器连接
SQL Server数据汇总完全解析
SQL查询语句使用精华
优化SQL Server服务器内存配置的策略
Sql server进行优化50招特效
用SQL语句实现异构数据库之间的导数据导入/出
SQL Server Compact Edition RC1 发布!
SQL Server死锁的分析
加快SQL Server备份和重新存储的速度
使用TSQL操作面试SQL Server开发人员
SQL 外链接操作小结 inner join left join right join

MSSQL 中的 全接触sqlserver异常与孤立事务


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 59 ::
收藏到网摘: n/a

 一、首先从sqlserver中error讲起,sql中错误处理有些怪辟 错误级别同是16但结果都不同。
  select * from 一个不在的表
  if @@error<>0
    print ’’这个没有输出’’
  go
  raiserror(’’’’,16,3)
  if @@error<>0
    print ’’这个输出了’’
  go
  exec(’’select * from 一个不在的表’’)
  if @@error<>0
    print ’’这个输出了’’
  go
  exec sp_executesql n’’select * from 一个不在的表’’
  if @@error<>0
    print ’’这个输出了’’
这样你可以发现通过exec或sp_executesql执行可疑的sql,这样就可以在后面捕捉到被异常终止的错误。

二、引出孤立事务:
  1、孤立事务的产生
    select @@trancount 当前连接的活动事务数 --当前连接的活动事务数为0
    begin tran
    select * from 一个不在的表
    if @@error<>0
    begin
      print ’’没有执行到这里来!’’
      if @@trancount<>0 rollback tran
    end
    commit tran
    select @@trancount 当前连接的活动事务数  --执行后你看看 当前连接的活动事务数为1,且重复执行会每次累加,这是很耗资源的。
  应为rollback根本就没有被回滚。
  2、使用现有手段解决孤立事务

    print @@trancount print ’’当前连接的活动事务数’’ --当前连接的活动事务数为0
    if @@trancount<>0 rollback tran --在这里写可以让孤立事务只保持到下次你的过程被调用
    begin tran
    select * from 一个不在的表
    if @@error<>0
    begin
      print ’’没有执行到这里来!’’
      if @@trancount<>0 rollback tran
    end
    commit tran
    ---执行后你看看 当前连接的活动事务数为1,但重复执行不会累加
    print @@trancount print ’’当前连接的活动事务数’’
三、使用 set xact_abort 来控制部分违反约束的错误的执行过程
  create table table1 (a int check(a>100))
  go
  set xact_abort on
  begin tran
    insert table1 values(10)
    print ’’这里没有被执行’’
  commit tran
  go
  
  print ’’’’ print ’’==============================================’’ print ’’’’
  
  set xact_abort off
  begin tran
    insert table1 values(10)
    print ’’这里被执行’’
  commit tran
  go
  drop table table1
但 set xact_abort 对于编译产生的错误确没有起作用,且同样会产生孤立事务
  set xact_abort on
  begin tran
    insert  一个不在的表 values(10)
    print ’’这里没有被执行’’
  commit tran
  go
  print ’’’’ print ’’==============================================’’ print ’’’’