在事务中调用N个存储过程,但这些存储过程都是有写事务的

C# code
    
    
SqlTransaction myTrans = sqlconn.BeginTransaction(); SqlCommand sqlcomm = new SqlCommand(); sqlcomm.Transaction = myTrans; try { sqlcomm.CommandText = " sp_proctestpara " ; // 这个存储过程中是有事力提交的 sqlcomm.Parameters.Add( " @txtName " , SqlDbType.NVarChar, 50 ); sqlcomm.Parameters[ " @txtName " ].Value = this .txtName.Text; SqlDataReader reader1 = sqlcomm.ExecuteReader(); reader1.Close(); sqlcomm.Parameters.Clear(); sqlcomm.CommandText = " testsp " ; // 现在在调用这个事条的时候出错,所以我的事务回滚,但上面的sp_proctestpara回滚不了,那这时要怎么办 sqlcomm.Connection = sqlconn; sqlcomm.CommandType = CommandType.StoredProcedure; sqlcomm.ExecuteNonQuery(); myTrans.Commit(); } catch (Exception ex) { Console.WriteLine(ex.ToString()); myTrans.Rollback(); Response.Write( " sorry! " ); } finally { sqlconn.Close(); dsdb.Close(); }
。。MS得把N个存储过程用同个事务串起来
不同事务就不行了。... 多个事务应该无法同时回滚 
不如 
把存储过程的中的事务 去掉吧 
只用程序中的改成用System.Transactions.TransactionScope控管事务,它会依照数据访问的情况自动提升事务的范围。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值