FIND_IN_SET を使用したカンマ区切り値による MySQL テーブルの検索
MySQL のようなリレーショナル データベースでは、カンマ区切り値の処理により検索時に問題が発生する可能性があります特定の記録用。 Customers と imap_emails という 2 つのテーブルがあるとします。customers テーブルには顧客の電子メールが含まれ、imap_emails テーブルにはカンマ区切りの「to」フィールドと「from」フィールドを持つ電子メールが保存されます。
imap_emails テーブルから電子メールを取得するには顧客の電子メール アドレスに基づいて、FIND_IN_SET 関数を利用できます。この関数は、特定の値がカンマ区切りリスト内に存在するかどうかを判断します。
FIND_IN_SET を使用したサンプル クエリは次のようになります。
SELECT * FROM imap_emails INNER JOIN customers ON FIND_IN_SET(customers.email, imap_emails.to) > 0;
このクエリは、条件に基づいて imap_emails テーブルと customer テーブルを結合します。顧客の電子メールが imap_emails テーブルの電子メールの「宛先」フィールドに含まれていること。結果には、この条件が満たされるすべての電子メールが含まれます。
ただし、電子メールに 2 つ以上の電子メール アドレスが含まれる場合、クエリは 1 つの電子メールに対して複数の行を返す場合があります。検索を絞り込むには、特定の電子メール アドレスを確認したり、顧客ごとの結果の数を制限したりするなど、WHERE 句で追加の条件を使用できます。
以上がFIND_IN_SET を使用してカンマ区切り値を含む MySQL テーブルを効率的に検索する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。