Maison > développement back-end > C++ > Pourquoi mon C# `ExecuteNonQuery` génère-t-il une erreur « Propriété de connexion non initialisée » ?

Pourquoi mon C# `ExecuteNonQuery` génère-t-il une erreur « Propriété de connexion non initialisée » ?

Mary-Kate Olsen
Libérer: 2025-01-04 05:47:39
original
447 Les gens l'ont consulté

Why is my C# `ExecuteNonQuery` throwing a

ExecuteNonQuery : propriété de connexion non initialisée

Le problème rencontré dans le code C# fourni est que la propriété Connection de SqlCommand nommée InsertCommand n'a pas été défini, ce qui entraîne l'erreur "ExecuteNonQuery : la propriété de connexion n'a pas été initialisée."

Pour résoudre ce problème erreur, vous devez attribuer explicitement la propriété Connection à InsertCommand. Ceci peut être réalisé en utilisant soit la propriété Connection, soit le constructeur de SqlCommand.

// Option 1: Using the Connection property
cmd.InsertCommand.Connection = connection1;

// Option 2: Using the constructor
cmd.InsertCommand = new SqlCommand("INSERT INTO Application VALUES (@EventLog, @TimeGenerated, @EventType, @SourceName, @ComputerName, @InstanceId, @Message) ", connection1);
Copier après la connexion

De plus, il est recommandé d'utiliser l'instruction using pour les objets IDisposable tels que SqlConnection et SqlCommand. Cela garantit que les ressources sont correctement éliminées après utilisation.

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) "))
{
    insertCommand.Connection = connection1;
    cmd.InsertCommand = insertCommand;

    connection1.Open();

    foreach (EventLogEntry entry in alog.Entries)
    {
        // Assign parameter values
        // ...

        // Execute the insert command
        cmd.InsertCommand.ExecuteNonQuery();
    }
}
Copier après la connexion

En effectuant ces ajustements, la propriété de connexion de InsertCommand sera correctement définie et le code devrait s'exécuter sans rencontrer l'erreur.

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