关于事务的一个问题,求指教

大葡萄八块一斤 2012-07-11 05:05:05
SqlConnection conn = DbopUtil.GetConn();
SqlTransaction tran = conn.BeginTransaction(System.Data.IsolationLevel.ReadUncommitted);
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.Transaction = tran;
try
{
....sql语句
tran.commit();

catch
{
tran.Rollback();
conn.close();
throw;
}

然后再下面
try
{
conn.open();
....sql语句
tran.commit();
}
catch
{
tran.Rollback();
conn.close();
throw;
}
下面这个有没有用的?
...全文
123 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
bolahbc 2012-07-12
  • 打赏
  • 举报
回复
事物一般是为了保证多个操作的一致性
比如你说的多条语句,要不都成功,要不都失败
你应该把多条语句放在一个事物,在提交的时候一次提交,确保多个语句或操作同时成功或失败
xuan.ye 2012-07-12
  • 打赏
  • 举报
回复
你的两个语句都执行完,才能commit;
xuan.ye 2012-07-12
  • 打赏
  • 举报
回复
这个挺麻烦的,你得根据具体的需求才能编写 分布式事务
  • 打赏
  • 举报
回复
不能,我是本地订单,要异步返回结果再进行执行,我再进行相应处理,两种操作来完成?怎么来
紫魂一号 2012-07-12
  • 打赏
  • 举报
回复
不能同时执行么??一个事物搞不定? 如果一个事物搞不定,建议用两种操作来完成,别混到一起
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 的回复:]

事物一般是为了保证多个操作的一致性
比如你说的多条语句,要不都成功,要不都失败
你应该把多条语句放在一个事物,在提交的时候一次提交,确保多个语句或操作同时成功或失败
[/Quote]

恩,这我知道,但是我现在就是有一个要做一个程序,这个页面,本地订单下单的有3句SQL语句同时执行,然后下面有个退款的4句SQL语句同时执行,这样就是要定义两个事务了吧,上面的提交了就提交,不能重复使用吗?
  • 打赏
  • 举报
回复
那我要执行两个,要重新定义一个事务就应该可以了吧比如

SqlConnection conn = DbopUtil.GetConn();
SqlTransaction tran = conn.BeginTransaction(System.Data.IsolationLevel.ReadUncommitted);
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.Transaction = tran;
try
{
....sql语句
tran.commit();

catch
{
tran.Rollback();
throw;
}
finally
{
conn.close();
}

然后再下面
conn.open();
SqlTransaction tran1 = conn.BeginTransaction(System.Data.IsolationLevel.ReadUncommitted);
cmd.Transaction = tran1;
try
{
conn.open();
....sql语句
tran.commit();
}
catch
{
tran1.Rollback();
throw;
}
finally
{
conn.close();
}
bolahbc 2012-07-11
  • 打赏
  • 举报
回复
可以用,但是失去了事物的意义
  • 打赏
  • 举报
回复
conn.close()写错地方了,没写finally里,不过不要紧,重要就是问同一个事务能不能再用。。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧