Maison >développement back-end >C++ >Pourquoi ExecuteNonQuery échoue-t-il avec « Connexion non initialisée » ?

Pourquoi ExecuteNonQuery échoue-t-il avec « Connexion non initialisée » ?

Susan Sarandon
Susan Sarandonoriginal
2025-01-03 11:10:38167parcourir

Why Does ExecuteNonQuery Fail with

Impossible d'exécuter une requête à l'aide de ExecuteNonQuery : connexion non initialisée

Un problème récurrent survient lors de la tentative d'exécution d'une requête à l'aide de ExecuteNonQuery :

ExecuteNonQuery: Connection property has not been initialized. 

Explication

Cette erreur se produit lorsque la propriété Connection de l’objet SqlCommand n’est pas affectée. La propriété Connection établit la connexion entre SqlCommand et la base de données. Sans connexion établie, ExecuteNonQuery ne peut pas être exécuté.

Solution

Pour résoudre ce problème, attribuez la connexion à la base de données à la propriété Connection de l'objet SqlCommand :

cmd.InsertCommand.Connection = connection1;

De plus, il est conseillé d'utiliser l'instruction using pour les ressources jetables comme SqlConnection. Cette pratique garantit une élimination appropriée des ressources et gère la fermeture des connexions :

using (var connection1 = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=syslog2;Integrated Security=True"))
{
    using (var cmd = new SqlDataAdapter())
    {
        using (var insertCommand = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) "))
        {
            // Assign connection
            insertCommand.Connection = connection1;
            
            // Set other properties...
            
            connection1.Open();
            // Execute query...
        }
    }
}

Optimisation

Pour optimiser davantage les performances, évitez de créer plusieurs connexions et adaptateurs de données pour chaque itération d'un boucle. Établissez la connexion et l'adaptateur de données une fois en dehors de la boucle et réutilisez-les dans la boucle. Cela réduit les frais liés à la création et à la fermeture de connexions plusieurs fois.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn