给定方法:
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: 即使将其包装在使用中,我仍然可以看到使用的连接(我关闭了连接池):
SELECT DB_NAME(dbid) as 'Database Name',
COUNT(dbid) as 'Total Connections'
FROM sys.sysprocesses WITH (nolock)
WHERE dbid > 0
GROUP BY dbid
编辑 2: 在我从这里得到的帮助下进行更多调试 - 答案是有人用池化硬编码连接字符串。感谢所有帮助 - 如果可以的话,我会将所有回复标记为答案。