DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: jeff1314
今日帖子: 10
在线用户: 10
导航: 论坛 -> 数据库专区 斑竹:liumazi,waterstone  
作者:
男 syzjc (好) ★☆☆☆☆ -
普通会员
2016/7/16 19:12:59
标题:
数据库存储过程中事物的问题请教 浏览:1388
加入我的收藏
楼主: 各位:两个存储过程里都执行事务,结尾都是
 COMMIT TRANSACTION
   endpro:
     return
  error:
    RAISERROR(@error_msg,16,-1)
    rollback transaction
并且都是执行中出错的话都是if @@error<>0
   begin
     select @error_msg='失败!'
     goto error
   end
现在有个疑问:在同一应用程序中,如果第一个存储过程执行中出错,程序抛出了异常,操作员接着去执行第二个存储过程做了很多写入数据的操作  这时第一个存储过程回滚了  那第二个存储过程写入的数据都没有了  怎么避免这样的情况?
----------------------------------------------
-
作者:
男 bdl1 (bdl1) ▲▲▲▲▲ -
普通会员
2016/7/17 10:56:11
1楼: 既然出了异常,为什么还要允许执行第二个存储过程呢?
----------------------------------------------
-我的博客
作者:
男 zhangpuqing (pupu) ★☆☆☆☆ -
普通会员
2016/7/17 15:07:06
2楼: 用事务啥.
----------------------------------------------
-
作者:
男 syzjc (好) ★☆☆☆☆ -
普通会员
2016/7/17 17:41:39
3楼: 是抛出了异常,但是用户不在意呀,他们点一下提示确定,就又去操作第二个去了,那就开始调用第二个存储过程了
----------------------------------------------
-
作者:
男 lsz100 (lsz) ★☆☆☆☆ -
盒子活跃会员
2016/7/26 15:17:42
4楼: 你这样做就不好
----------------------------------------------
我为人人为我
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行82.03125毫秒 RSS