Connection 对象的 Close 和 Dispose

作者:vkvi 来源:ITPOW(原创) 日期:2007-8-15

Connection 对象(包括 SqlConnection 和 OleDbConnection)其中有两个方法:Close 和 Dispose。

需不需要调用这两个方法?

需要!通过 Finalize(析构函数)、Dispose、Close 的区别与使用和 MSDN 相关资料,可以得知 Connection 对象的 Close 是关闭数据库连接,并不是销毁对象,所以良好的习惯是先调用 Close,再调用 Dispose。

下面的程序思路可以帮助您证明 Connection 对象的 Close 并没有销毁对象。

SqlConnection conn = new SqlConnection(connectionstring);
conn.Open();
conn.Close();
//代码省略,这里再次使用 conn 对象,conn 对象仍然存在
conn.Dispose();
//代码省略,这里再次使用 conn 对象,报错说 conn 没有初始化

说明

  • 这里所说的 Close 方法是针对于 Connection 对象,其它对象的 Close 方法并不是一定没有释放资源。
  • Close 方法并不是真正的关闭数据库连接,而是将连接放入连接池
  • using 语句中可以自动调用 Dispose。
相关文章