首页产品库评测行情新闻|手机数码笔记本台式机DIY硬件数字家庭数码相机办公外设|软件下载游戏开发|社区

更多

数码相机
MP4
LCD
机箱
音箱

软件资讯设计 工具 系统 开发 安全 办公 陶吧 IT教育 Vista频道 | 下载中心酷我音乐盒 腾讯QQ
天极网 > 开发频道>SQL Server的怪辟:异常与孤立事务

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

2007-07-03 11:24作者:pengdali出处:论坛整理责任编辑:webbtob

  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 ''

  set xact_abort off
  begin tran
    insert  一个不在的表 values(10)
    print '这里没有被执行'
  commit tran
  go

  select @@trancount 当前连接的活动事务数 ---有两个孤立事务
  if @@trancount<>0 rollback tran

  对于sql中怪辟的各种错误,和孤立事务在t-sql编程中一定要注意,小心孤立事务的陷阱,尽量避免浪费或孤立资源,Microsoft公开宣布过SQLServe下一版本Yukon将有内置异常处理语法。那时可以通过代码对无法预料的错误有更好的控制。


  阅读关于 SQL Server 怪辟 异常 孤立 事务 的全部文章
共2页。 上一页12
进入 最权威的Windows 7论坛 查看网友讨论

软件频道最新更新

热点推荐

IT嘉年华

编辑推荐

软件下载

热门
推荐

网友关注

软件
资料
游戏

装机推荐

文章排行

本周
本月
最新更新
天极服务|关于我们|About us|网站律师|RSS订阅|友情合作|加入我们|天极动态|网站地图|意见反馈|MSN/QQ上看天极
Copyright (C) 1999-2012 Yesky.com, All Rights Reserved 版权所有 天极网络