MySQL でカンマ区切り値を含む電子メールを検索する
カンマ区切り値 (CSV) を含む MySQL テーブルを操作する場合、データを検索する挑戦的になる可能性があります。たとえば、CSV として保存された電子メール アドレスを含むテーブルがある場合、特定の電子メール アドレスに基づいてクエリを実行する必要がある場合があります。
質問:
データベース「customers」(顧客の電子メール アドレスを含む) と「imap_emails」(CSV 値を含む「to」および「from」フィールドを含む) の 2 つのテーブルで構成されます。目標は、「customers」テーブルから電子メールを取得し、「imap_emails」テーブルの「to」フィールドと「from」フィールドで電子メールを検索することです。
FIND_IN_SET を使用した解決策:
このような検索を実行する効率的な方法の 1 つは、FIND_IN_SET 関数を使用することです。この関数は、カンマ区切りリスト内の指定された文字列の位置を返します。これを結合と組み合わせることで、目的の結果を得ることができます。
クエリの例:
SELECT * FROM imap_emails INNER JOIN customers ON FIND_IN_SET(customers.email, imap_emails.to) > 0
このクエリは、「imap_emails」と「imap_emails」の間の内部結合を実行します。顧客の電子メール アドレスが「imap_emails」テーブルの「to」フィールドに存在するという条件に基づく「customers」テーブル (次のように決定されます) FIND_IN_SET).
注:
以上がMySQL でカンマ区切りの電子メール アドレスを効率的に検索するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。