Heim >Backend-Entwicklung >C++ >Wie gehe ich mit dem Fehler „DBNull kann nicht implizit in Int konvertiert werden' in C# um?
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:
<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>
<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>
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!