Access911.net   |   a9BBS   |   OTaA System  
  搜索文章:  
Access911欢迎您光临  
   主页      上传      繁體版       论坛     
设为首页  |  加入收藏   
  
你现在的位置:文章索引 -> 文章分类 -> ASP/ASP.NET  
 首页|  近日更新|  下载  |  文章索引  |  搜索|  术语|  承接工程|  
 
系统正在加载内容,请耐心等待...
 
 查询
 窗体
 报表
 
 
 VBA
 函数
 ADO/DAO/ADO.NET
 API
 ADP
 安全
 发布
 OA
 ASP/ASP.NET
 其他语言
 控件
 DELPHI
 C#/.Net
 本站
 其他
 小例程
 常用软件
 参考文档
 业主作品
 网友大作
 
 
友情链接
 access911.net
 
访问人次
 1702186
 
站长 E-Mail
 net911@sina.com
 access911@gmail.com
 
RSS 订阅

显示附加信息 >>>

关于 ASP 变量的生命周期,CONNECTION 关闭的问题

作者:cg1  摘自:access911.net  :cg1  更新日期:2004-9-27  浏览人次:

 

问题:

关于 ASP 变量的生命周期


比如有一个页面

<%
dim conn
set conn=server.createobject ("adodb.connection")
conn.open strConn
dim strsql
strsql=.............

conn.execute strsql

%>

当这个页面被客户端请求时, IIS 帐号负责将 CONN 打开,一旦返回结果给客户端
后,这个 CONN 还打开么?还是我必须在页面的尾部加上关闭 CONN 的代码?我不是很
清楚。

疑问,既然每次都解释执行一遍,那么一个页面被全部执行完毕后,其中的变量不会被
销毁么?

如果CONN这个变量已经被销毁,那么 CONNECTION 就应该是关闭的把?如果仍然是打开
的,那么就永远打开了么?不会有 TIMEOUT 么?

 


回答:


当一个ASP的页面被请求时,服务端实际上是对该页面进行即时的解释执行,因此一般来说您的页面中的代码都是每次请求都执行一遍,所有的变量也是在每次页间的执行过程中有效。并且这些变量在多次请求间不会保持状态。 所以我们如果创建了一个connection 变量并且打开了数据库连接,一定要记得在最后关闭连接。不然就会丢失了对这个连接的引用。


不错,页面执行结束,变量生命周期结束,被销毁。但是对于Connection对象,我们如果没有显式关闭它,在变量销毁时这个连接就相当于丢失了引用。它仍然开着,至于超时被关闭,这已经是数据库那边做的工作,与我们的代码无关了。 所以我们的代码中必须保证每次使用后都显式关闭数据库连接。

 

 

 
相关文章
     没有手动相关文章
     如何使ACCESS主窗体右上角的一些按钮失效(禁止),比如关闭、最大化、最小化、还原
     如何关闭一个进程
     如何用access开一个ie窗口,然后再关闭?
     如何关闭已经打开的所有窗体?
     如何让用户不能随意退出(退出前提示)?
 
评论
     查看或发表更多的评论,请单击这里。
 
 
 
 
 
   
  Access911.net   |   a9BBS   |   OTaA System   |
建站日期:2000年4月2日  |  设计施工:陈格 ( access911 & cg1 )
 Copyright © 2000 - 2003 COMET, 陈格 保留所有权利