给定以下方法:
internal static DataSet SelectDataSet(String commandText, DataBaseEnum dataBase)
{
var dataset = new DataSet();
SqlConnection sqlc = dataBase == DataBaseEnum.ZipCodeDb
? new SqlConnection(ConfigurationManager.AppSettings["ZipcodeDB"])
: new SqlConnection(ConfigurationManager.AppSettings["WeatherDB"]);
SqlCommand sqlcmd = sqlc.CreateCommand();
sqlcmd.CommandText = commandText;
var adapter = new SqlDataAdapter(sqlcmd.CommandText, sqlc);
adapter.Fill(dataset);
return dataset;
}
为什么在调用方法超出范围或sqlc没有更多引用后,sqlc(SqlConnection)没有被释放/关闭?
编辑1: 即使将其包装在using中,我仍然可以看到连接(我已将连接池关闭):
SELECT DB_NAME(dbid) as 'Database Name',
COUNT(dbid) as 'Total Connections'
FROM sys.sysprocesses WITH (nolock)
WHERE dbid > 0
GROUP BY dbid
编辑2: 在这里得到的帮助下进行了更多的调试 - 答案是有人硬编码了一个使用池化的连接字符串。感谢所有的帮助 - 如果可以的话,我会将所有的回答都标记为答案。