ホームページ > データベース > mysql チュートリアル > LaravelのJSON列内のメールアドレスをクエリするにはどうすればよいですか?

LaravelのJSON列内のメールアドレスをクエリするにはどうすればよいですか?

Barbara Streisand
リリース: 2024-10-29 00:24:02
オリジナル
889 人が閲覧しました

How to Query for Email Addresses within a JSON Column in Laravel?

Laravel で JSON 列からデータを取得する

問題:

Laravel アプリケーションには to 列があります。メール テーブルに JSON 型のメール アドレスを次の形式で保存します:

<code class="JSON">[
    {
        "emailAddress": {
            "name": "Test", 
            "address": "[email&#160;protected]"
        }
    }, 
    {
        "emailAddress": {
            "name": "Test 2", 
            "address": "[email&#160;protected]"
        }
    }
]</code>
ログイン後にコピー

「[email protected]」に送信されたすべてのメールのコレクションを取得する必要があります。

解決策:

Laravel の Eloquent を使用すると、whereJsonContains メソッドを使用して JSON 列内の特定の値を検索できます。ただし、最初のクエリ:

<code class="php">DB::table('emails')->whereJsonContains('to->emailAddress->address', '[email&#160;protected]')->get();</code>
ログイン後にコピー

は、配列キー内では矢印演算子 (->) が無効であるため、一致を返しません。この問題を解決するには、代わりにネストされた配列を使用します。

<code class="php">DB::table('emails')
   ->whereJsonContains('to', [['emailAddress' => ['address' => '[email&#160;protected]']]])
   ->get();</code>
ログイン後にコピー

このクエリは、「[email protected]」に等しい電子メール アドレスを正しく検索し、目的のコレクションを返します。

以上がLaravelのJSON列内のメールアドレスをクエリするにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート