ホームページ >データベース >mysql チュートリアル >SQL Float を C# Float にキャストすると InvalidCastException がスローされるのはなぜですか?
SQL Float と C# Float の不一致
Float データ型を使用して SQL データベースから値を取得し、それをフロート データ型に割り当てようとしたときfloat 型の C# 変数を使用すると、InvalidCastException が発生する可能性があります。これは、SQL float データ型が C# の double に対応するためです。
例:
次のコードを考えてみましょう:
DataRow exercise = _exerciseDataSet.Exercise.FindByExerciseID(65); _AccelLimit = (float)exercise["DefaultAccelLimit"]; // Throws InvalidCastException
例外の理由:
オブジェクトから float への明示的なキャスト基になるデータ型が double であるため、上記のコードは実行できません。 SQL float は 64 ビット浮動小数点値として格納されます。これは、C# float データ型で表される 32 ビット浮動小数点値とは異なります。
解決策:
この問題を解決するには、取得した値を double にキャストする前に明示的に変換します。 float:
_AccelLimit = (float)(double)exercise["DefaultAccelLimit"];
この変換により、取得された値が double に適切にキャストされ、変数の宣言されたデータ型と一致するように float に変換されます。
以上がSQL Float を C# Float にキャストすると InvalidCastException がスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。