ExecuteNonQuery需要一个开放且可用的Connection。连接的当前状态已关闭。ExecuteNonQuery需要一个开放且可用的Connection。连接的当前状态已关闭
我在这里做错了什么?我假设你可以重用连接?
感谢您的帮助!
using (SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStrings["LocalSqlServer"].ToString()))
{
cn.Open();
// If we are reverting to an old type
if (pageAction == "revert")
{
debug.Text = "FLAG 1";
// Get the revert ID
int revertingID = int.Parse(Request.QueryString["revID"]);
bool rowsReturned = false;
debug.Text = "FLAG 2 - " + revertingID.ToString();
// Set all to 0
using (SqlCommand cmd = new SqlCommand("SELECT ID FROM tblSiteSettings WHERE ID = " + revertingID, cn))
{
// If it exists
SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
if (rdr.Read())
{
rowsReturned = true;
}
rdr.Close();
}
debug.Text = "FLAG 3 - " + rowsReturned.ToString();
// Set new active and reset others
if (rowsReturned == true)
{
using (SqlCommand cmd = new SqlCommand("UPDATE tblSiteSettings SET isActive = 1 WHERE ID = " + revertingID, cn))
{
cmd.ExecuteNonQuery();
}
using (SqlCommand cmd = new SqlCommand("UPDATE tblSiteSettings SET isActive = 0 WHERE ID <> " + revertingID, cn))
{
cmd.ExecuteNonQuery();
}
}
//debug.Text = "FLAG 4 - ";
}
使用()语句时,它的命令是否在关闭连接时被封装,以及它是否处置SqlCommand? – Tommy 2010-08-23 13:52:59
@Tommy,不是我所知 - SqlCommand.Dispose的文档没有调用它,所以我会假设不是(http://msdn.microsoft.com/zh-cn/library/system .data.sqlclient.sqlcommand.dispose.aspx) – Rob 2010-08-23 13:58:50
好的调用,如果连接定义被封装在Using块中,那么它会。 http://stackoverflow.com/questions/410222/does-connection-close-when-command-is-disposed-and-the-connection-is-defined-dire – Tommy 2010-08-23 14:06:19