首頁  >  文章  >  資料庫  >  SQL Server的怪辟:异常与孤立事务

SQL Server的怪辟:异常与孤立事务

WBOY
WBOY原創
2016-06-07 15:04:491201瀏覽

一、首先从SQLServer中Error讲起,SQL中错误处理有些怪辟 错误级别同是16但结果都不同。 以下是引用片段: select * from 一个不在的表 if @@error0 print '这个没有输出' go raiserror('',16,3) if @@error0 print '这个输出了' go exec('select * from 一

  一、首先从SQLServer中Error讲起,SQL中错误处理有些怪辟 错误级别同是16但结果都不同。

以下是引用片段:
select * from 一个不在的表
  if @@error0
    print '这个没有输出'
  go

  raiserror('',16,3)
  if @@error0
    print '这个输出了'
  go

  exec('select * from 一个不在的表')
  if @@error0
    print '这个输出了'
  go

  exec sp_executesql N'select * from 一个不在的表'
  if @@error0
    print '这个输出了'

  这样你可以发现通过exec或sp_executesql执行可疑的sql,这样就可以在后面捕捉到被异常终止的错误。

  二、引出孤立事务

  1、孤立事务的产生

以下是引用片段:
select @@trancount 当前连接的活动事务数 --当前连接的活动事务数为0

    begin tran

    select * from 一个不在的表
    if @@error0
    begin
      print '没有执行到这里来!'
      if @@trancount0 rollback tran
    end

    commit tran

  select @@trancount 当前连接的活动事务数 --执行后你看看 当前连接的活动事务数为1,且重复执行会每次累加,这是很耗资源的。

  应为rollback根本就没有被回滚。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn