Heim > Backend-Entwicklung > C++ > Wie gehe ich mit dem Fehler „DBNull kann nicht implizit in Int konvertiert werden' in C# um?

Wie gehe ich mit dem Fehler „DBNull kann nicht implizit in Int konvertiert werden' in C# um?

Patricia Arquette
Freigeben: 2025-01-10 22:57:48
Original
183 Leute haben es durchsucht

How to Handle

Kann DBNull nicht implizit in Int konvertieren?

Fehler im Codeausschnitt: „Implizite Konvertierung von DBNull nach int nicht möglich.“ Dies liegt an der Natur des ?:-Operators, da dieser erfordert, dass die von ihm ausgewerteten Ausdrücke vom gleichen Typ sind.

In diesem Beispiel ist der erste Ausdruck (AgeItem.AgeIndex) eine Ganzzahl, während der zweite Ausdruck (DBNull.Value) vom Typ DBNull ist. Diese Typen sind inkompatibel und verursachen Fehler.

Lösung: In Objekt umwandeln oder Null-Koaleszenzoperator verwenden

Um dieses Problem zu beheben, haben Sie zwei Möglichkeiten:

  • In Objekt umwandeln: AgeItem.AgeIndex in einen Objekttyp umwandeln, der Ganzzahlen und DBNull-Werte aufnehmen kann:
<code class="language-csharp">SqlParameter[] parameters = new SqlParameter[1];     
SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int);
planIndexParameter.Value = (object)AgeItem.AgeIndex ?? DBNull.Value;
parameters[0] = planIndexParameter; </code>
Nach dem Login kopieren
  • Verwenden Sie den Null-Koaleszenzoperator (??): ??Der Null-Koaleszenzoperator gibt den Wert des ersten Ausdrucks zurück, wenn der erste Ausdruck nicht null ist, gibt er den Wert des zweiten Ausdrucks zurück . Dies kann verwendet werden, um DBNull.Value zuzuweisen, wenn AgeItem.AgeIndex null ist:
<code class="language-csharp">SqlParameter[] parameters = new SqlParameter[1];     
SqlParameter planIndexParameter = new SqlParameter("@AgeIndex", SqlDbType.Int);
planIndexParameter.Value = AgeItem.AgeIndex ?? DBNull.Value;
parameters[0] = planIndexParameter; </code>
Nach dem Login kopieren

Mit diesen Lösungen können Sie einem SqlParameter eine Ganzzahl oder DBNull.Value zuweisen, ohne dass Typkonvertierungsfehler auftreten.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit dem Fehler „DBNull kann nicht implizit in Int konvertiert werden' in C# um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage