ホームページ >データベース >mysql チュートリアル >MySQL SELECT クエリがフロートを比較すると失敗するのに、比較を削除すると機能するのはなぜですか?
MySQL SELECT クエリにおける浮動小数点比較の問題の解決
MySQL SELECT クエリでは、浮動小数点値を比較するときに精度の問題が発生する可能性があります。この問題に対処するために、次の質問を検討してみましょう:
質問:
比較を削除すると正しい結果が返されるのに、float 等価比較を使用した SELECT クエリが失敗するのはなぜですか行?一致を成功させるために、操作の前に浮動小数点を 2 桁にキャストするにはどうすればよいですか?
答え:
この問題は、MySQL に固有の浮動小数点精度に起因します。これを解決するには、float 列を 10 進数型にキャストし、特定の桁数までの精度を確保します。
解決策:
次のクエリは正常に一致します。浮動小数点値を 10 進数にキャストする:
SELECT * FROM `table` WHERE CAST(`price` AS DECIMAL) = CAST(101.31 AS DECIMAL);
代替解決策:
あるいは、価格列を DECIMAL に変更することを検討することもできます。これは、より適しています。金銭的な値を処理するためのものであり、より優れた精度制御を提供します。
以上がMySQL SELECT クエリがフロートを比較すると失敗するのに、比較を削除すると機能するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。