事务、锁 的问题

prettyBoy1 2005-10-10 02:00:51
SqlConnection myConnection = new SqlConnection(myConnString);
myConnection.Open();
SqlCommand myCommand = myConnection.CreateCommand();
SqlTransaction myTrans;

// Start a local transaction
myTrans = myConnection.BeginTransaction (IsolationLevel.ReadUncommitted,"SampleTransaction");
// Must assign both transaction object and connection
// to Command object for a pending local transaction
myCommand.Connection = myConnection;
myCommand.Transaction = myTrans;

try
{
myCommand.CommandText = "insert into buser(username,realname) values('sss5','sss5')";
myCommand.ExecuteNonQuery();
myCommand.CommandText = "insert into mywt_mis..buser(username,realname) values('sss6','sss6')";
myCommand.ExecuteNonQuery();
myTrans.Commit();
Console.WriteLine("Both records are written to database.");
}
catch(Exception e)
{
myTrans.Rollback("SampleTransaction");
}
finally
{
myConnection.Close();
}

我的问题是:我想要在事务执行期间,别人仍然可以访问该表,可以用select * from buser来查询该表。我先在用了 级别最低的锁ReadUncommitted,我在中间设置了断电,执行到断点,我用sql 查询分析器, 执行:select * from buser,提示锁超时。 不是说级别低的锁,不锁吗,还可以读脏数据,怎么不能读呢?
...全文
91 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
pontus 2005-10-24
  • 打赏
  • 举报
回复
插入数据时使用了排它锁,其他事务不能读取或者修改

62,046

社区成员

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

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

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

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