关闭SqlServer数据库疑问,简单问题

gxboy 2003-10-19 07:45:34
<%@ Import NameSpace="System.Data" %>
<%@ Import NameSpace="System.Data.SqlClient" %>

<script runat="server">
Dim objcommand As SqlCommand
Dim conn As New SqlConnection("Server=x;User ID=x;Password=x;Database=x")
Dim sql As String
</script>

<%
sql = "select top 10 name from my order by id desc"
conn.open()
Try
objcommand = New SqlCommand(sql, conn)
objcommand.ExecuteReader(CommandBehavior.CloseConnection)
objcommand.Dispose()
objcommand = Nothing
Catch e As Exception
Response.Write(e.ToString)
Finally
conn.close()
conn = nothing
Me.Dispose()
End Try
%>
--------------------

直接 conn.open 后使用close方法就可立即清除连接,在sqlserver里看见的连接数为0,这是正常的。

但在中间加上如上述代码,就不管用了,我使用了很多种方法都还是一样的效果,反正在sqlserver里连接数就是1,至少要等几分种的时间才自动清除连接数。

于是在asp下对同一个数据库作测试,发现asp也不能即时清除连接数,但自动清除时间明白缩短几倍。

后来反复测试,是有一句代码的原因

conn.open()
objcommand.ExecuteReader(CommandBehavior.CloseConnection)
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
conn.close()

就是这一句的原因,但不知道为什么。请大侠指点。
...全文
45 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
guoyan19811021 2003-10-20
  • 打赏
  • 举报
回复
Connection.Close
feeling 2003-10-20
  • 打赏
  • 举报
回复
objcommand.Connection.Close()
gxboy 2003-10-19
  • 打赏
  • 举报
回复
我这样写也可以关啊,但就是不行。
webdiyer 2003-10-19
  • 打赏
  • 举报
回复
在你的代码中,你只要关闭SqlDataReader就行了,数据库连接会自动关闭。
wolf004 2003-10-19
  • 打赏
  • 举报
回复
俺没学过!

62,046

社区成员

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

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

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

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