现在的位置: 网页制作教程网站制作经验 >正文
数据库教程

关闭数据库连接conn.Close()与conn.Dispose()的区别

发表于2016/10/21 网站制作经验 0条评论 ⁄ 热度 5,790℃

conn.Close()和conn.Dispose()都可以关闭数据库连接,那他们之间有什么区别呢?

conn.Close()与conn.Dispose()的区别

执行Close()不释放数据库连接池的资源,而是把连接放回连接池中待用;

Dispose则会把这个连接彻底销毁掉,不会再放入连接池。如果所有的连接都被Dispose的话,每次使用数据库都必须重新创建连接,这样很耗费资源。因此不要用Dispose。

conn.Close()与conn.Dispose()

也就是说Close()是关闭,Dispose()是释放对象(回收)。

比如Conn对象,Close过后,Conn这个对象本身还存在内存中,需要在使用的时候,可以直接使用。

而调用Dispose()后,Conn对象被回收,Conn对象已经不存在了,下次再需要使用的时候,对象就不存在了,需要重新创建。

.NET会维护连接池,连接Open的时候从连接池中取出一个没有使用的连接,用完以后Close()的时候再放回连接池,实际上没有创建新的连接,从而提高了性能。 因此为了性能,为了使用连接池,不可以dispose,但必须close() 。

.NET中所有创建的对象有垃圾收集器进行管理,因些也不需要我们手动释放或dispose。

扩展阅读:asp如何连接数据库php如何连接SQLServer2005数据库

  • 暂无评论