ExecuteNonQuery requiert une connexion ouverte et disponible. L'état actuel de la connexion est fermé.ExecuteNonQuery requiert une connexion ouverte et disponible. L'état actuel de la connexion est fermé.
Qu'est-ce que je fais mal ici? Je suppose que vous pouvez réutiliser la connexion?
Merci pour toute aide!
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 - ";
}
Est-ce que l'instruction Using() ses commandes sont encapsulées dans la fermeture de la connexion quand elle dispose de SqlCommand? – Tommy
@Tommy, pas aussi loin que je sache - la documentation pour SqlCommand.Dispose ne l'appelle pas, donc je suppose que non (http://msdn.microsoft.com/fr-fr/library/system .data.sqlclient.sqlcommand.dispose.aspx) – Rob
Bon appel, si la définition de connexion était enveloppée dans un bloc Using, alors ce serait le cas. http://stackoverflow.com/questions/410222/does-connection-close-when-command-is-disposed-and-the-connection-is-defined-dire – Tommy