MySQL SELECT クエリの大文字と小文字の区別
デフォルトでは、MySQL SELECT クエリは大文字と小文字を区別しません。これは、クエリ SELECT * FROM table` WHERE `Value` = "iaresavage" は、Value` 列の値が実際には 'IAreSavage' であっても結果を返すことを意味します。
大文字と小文字の区別のオーバーライド
ただし、このデフォルトの動作をオーバーライドし、二項演算子を使用して大文字と小文字を区別した比較を実行できます。これを行うには、クエリを次のように変更します。
SELECT * FROM `table` WHERE BINARY `Value` = "iaresavage"
これで、クエリは、大文字と小文字に関係なく、Value 列の値が指定された文字列と正確に一致する場合にのみ結果を返します。
例
次の表を考えてみましょう。
Value |
---|
iaresavage |
IAreSavage |
場合次のクエリを実行すると、
SELECT * FROM `table` WHERE `Value` = "iaresavage"
クエリでは大文字と小文字が区別されないため、両方の行が返されます。
ただし、次のクエリを実行すると、
SELECT * FROM `table` WHERE BINARY `Value` = "iaresavage"
大文字と小文字を区別した比較により 2 行目は除外されるため、最初の行のみが返されます。
以上がMySQL は SELECT クエリの大文字と小文字の区別をどのように処理しますか?また、それをオーバーライドするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。