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。