ホームページ >データベース >mysql チュートリアル >MySQL IN() クエリが複数の一致する ID を持つ行を返さないのはなぜですか?

MySQL IN() クエリが複数の一致する ID を持つ行を返さないのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-04 16:38:02851ブラウズ

Why Doesn't MySQL IN() Query Return Rows with Multiple Matching IDs?

マルチ ID レコードの MySQL IN () クエリの問題

クエリの実行時:

SELECT * FROM table WHERE id IN (1,2,3,4);

複数の ID に基づいてデータを取得すると、一致する複数の ID を含む行が返されないという問題が発生する可能性があります。このクエリは次のように変換されます:

SELECT * FROM table WHERE id='1' or id='2' or id='3' or id='4';

セット内の任意の 1 つの ID に一致する行のみを取得します。

解決策: SET データ型を使用する

この制限に対処するには、id 列のデータ型を SET に変更することを検討できます。これにより、複数の値を 1 つの列に保存できます。この変更を行った後、クエリで FIND_IN_SET 関数を使用できます。

SELECT * FROM table WHERE FIND_IN_SET('1', id);

このクエリは、他の値に関係なく、id 列の値の 1 つとして「1」を含むすべての行を返します。現在。これにより、レコードを複数の ID と照合するより柔軟な方法が提供されます。

以上がMySQL IN() クエリが複数の一致する ID を持つ行を返さないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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