ホームページ >データベース >mysql チュートリアル >MySQL の文字列を 0 と比較すると TRUE が返される場合があるのはなぜですか?
MySQL の不可解な文字列と 0 の比較: 謎を解く
MySQL クエリを実行すると、文字列カラムの比較という予期しない結果が発生する可能性があります。 (数値として) 0 を指定すると、予期せず TRUE が返されます。この動作は、特に他の数値比較で予期した結果が得られる場合に直観に反するように見えることがあります。
MySQL の基礎となる仕組みを詳しく調べると、その答えはその自動変換機能にあります。 MySQL には、特定の条件に基づいて文字列を数値にシームレスにキャストする機能があります。
このロジックを使用すると、「文字列」の謎を解明できます。 = 0 は TRUE を返します。 'string' は数値で始まっていないため、MySQL はそれを 0 として解釈し、結果として SELECT 0 = 0 という比較が行われ、当然のことながら TRUE と評価されます。
ただし、これらの変換は数値で始まることに注意することが重要です。文字列を直接比較する場合には発生しません。たとえば、'0string' = 'string' は意図したとおり FALSE を生成します。
あるいは、演算子 ( など) を使用した明示的な変換により、MySQL は文字列を数値として扱うように強制されます。 ' ' 演算子を使用する場合、MySQL は '0string' と 0 を合計し、両方の値を数値 (0 0) に変換し、予想される TRUE 値を返します。
さらに、MySQL では、数字を含む文字列の合計も許可されます。たとえば、'1abc' '2ef' は実質的に 1 2 に変換され、期待される結果 3 が生成されます。
これらの舞台裏の仕組みを理解すると、MySQL の文字列と 0 の比較の謎が解明され、以下のことが可能になります。正確なデータ解釈と正確なクエリ構築。
以上がMySQL の文字列を 0 と比較すると TRUE が返される場合があるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。