ホームページ >バックエンド開発 >C++ >C# で SqlParameter に代入するときに Null 値を処理する方法は?

C# で SqlParameter に代入するときに Null 値を処理する方法は?

Linda Hamilton
Linda Hamiltonオリジナル
2025-01-10 22:52:46747ブラウズ

How to Handle Null Values When Assigning to a SqlParameter in C#?

C# で SqlParameter に null 値を代入する

提供されたコードで「DBNull から int に暗黙的に変換できません。」というエラーが発生しました。このエラーは、SqlParameter の Value プロパティに int 値または DBNull 型の値を割り当てようとする条件演算子から発生します。残念ながら、これらのデータ型には互換性がないため、演算子は適切な戻り値の型を決定できません。

回避策は、AgeItem.AgeIndex 値を object 型にキャストするか、null 合体演算子 (??) を使用することです。 AgeItem.AgeIndex を object 型にキャストすると、Value プロパティに確実に割り当てることができます (Value プロパティにはオブジェクトが必要です)。あるいは、?? 演算子を使用すると、よりクリーンなアプローチを実現できます。

<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>
この場合、?? は AgeItem.AgeIndex を評価し、それが null の場合は、パラメーターの値を DBNull.Value に割り当てます。型変換または null 合体演算子を利用することで、上記のエラーを解決し、必要な値を SqlParameter の Value プロパティに割り当てることができます。

以上がC# で SqlParameter に代入するときに Null 値を処理する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。