使用DataReader和事务时报错: 已有打开的与此连接相关联的 DataReader,必须首先将它关闭。

xinuaile 2004-01-18 11:02:55
异常详细信息: System.InvalidOperationException: 已有打开的与此连接相关联的 DataReader,必须首先将它关闭。

while(dr.Read())
{
show.Text="<font color=red ><b> customerid is "+dr[0]
+"</b></font> ...companyname is "+dr["companyname"]
+"contactname is >"+dr[dr.GetOrdinal("contactname")];
}
tra.Commit();
dr.Close();

}
catch(Exception ex)
{
tra.Rollback();
}
...全文
73 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
coollzh 2004-01-31
  • 打赏
  • 举报
回复
不是关闭连接,是关闭DataReader
xinuaile 2004-01-30
  • 打赏
  • 举报
回复
关闭了连接 , 既然断开了 连接 ,那末 还怎么提交
coollzh 2004-01-29
  • 打赏
  • 举报
回复
因为你的reader占了连接,所以没有commit,
所以你要先关闭reader,把连接空出来,但如果你用了commandbehavior.close的话就不同了
xinuaile 2004-01-29
  • 打赏
  • 举报
回复
但是先 关闭了连接, 再commit , 怎么提交的?
ZXYSOSO 2004-01-19
  • 打赏
  • 举报
回复
http://expert.csdn.net/Expert/topic/2078/2078925.xml?temp=.3058588
xtmyname 2004-01-19
  • 打赏
  • 举报
回复
同意 redbb(....Dotneter....)
setking 2004-01-18
  • 打赏
  • 举报
回复
对!要先关闭了dr.Close()连接然后才能执行tra.Commit()
elite2018 2004-01-18
  • 打赏
  • 举报
回复
tra.Commit();
dr.Close();

===>>>

dr.Close();
tra.Commit();

62,074

社区成员

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

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

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

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