关于监视SqlConnection状态的问题

离子漂浮物 2009-04-08 10:53:34

if (Conn.State != ConnectionState.Open)
{
try
{
Conn.Open();
}
catch
{
System.Web.HttpContext.Current.Response.Write("网站数据库服务器正在维护中,请稍候重试。");
System.Web.HttpContext.Current.Response.End();
}
}


以上是我用来作数据库open的监视语句,在正常情况下,如果open失败的话,就会提示“网站数据库服务器正在维护中,请稍候重试。”
但如果页面刷新过一次,完成了.net的加载并显示出数据后,数据库突然关闭后再次刷新页面就会提示:

"在从服务器接收结果时发生传输级错误。 (provider: 共享内存提供程序, error: 0 - 系统无法打开文件。) "

提示行居然是SqlCommand的ExecuteReader();行,

想问一下除了try SqlCommand的ExecuteReader() 外还有别的什么更好的错误过滤方式,如上面代码那个核实某个状态后提示信息呢?
...全文
170 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
liu4545533 2009-04-10
  • 打赏
  • 举报
回复
没有管理数据库啊、
离子漂浮物 2009-04-10
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 lude8880 的回复:]
最好在catch的时候加上conn.close()
[/Quote]

这段代码是放在using里的,不加close也一样会close。

现在问题是怎么样防止数据库服务器突然关闭
lude8880 2009-04-10
  • 打赏
  • 举报
回复
最好在catch的时候加上conn.close()
opou 2009-04-08
  • 打赏
  • 举报
回复
学习了
itcrazyman 2009-04-08
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 hwj383 的回复:]
ExecuteReader()会连接并执行查询,你断开了数据库连接,当然会出现此错误,try catch住吧
[/Quote]
mark up
「已注销」 2009-04-08
  • 打赏
  • 举报
回复
ExecuteReader()会连接并执行查询,你断开了数据库连接,当然会出现此错误,try catch住吧
离子漂浮物 2009-04-08
  • 打赏
  • 举报
回复
我说的是asp.net在加载并显示过数据后,数据库服务器突然关闭,导致出现
"在从服务器接收结果时发生传输级错误。 (provider: 共享内存提供程序, error: 0 - 系统无法打开文件。) "
的错误提示。
  • 打赏
  • 举报
回复
数据库服务打开后没有关闭

62,046

社区成员

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

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

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

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