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
Libérer: 2025-01-03 11:10:38
original
112 Les gens l'ont consulté

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. 
Copier après la connexion

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;
Copier après la connexion

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...
        }
    }
}
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal