Heim > Datenbank > MySQL-Tutorial > Wie suche ich nach E-Mails in einem JSON-Array in der Spalte „An' von Laravel?

Wie suche ich nach E-Mails in einem JSON-Array in der Spalte „An' von Laravel?

Patricia Arquette
Freigeben: 2024-10-29 04:21:29
Original
808 Leute haben es durchsucht

How to Search for Emails within a JSON Array in Laravel's

JSON-Spalten in Laravel durchsuchen

Bei der Arbeit mit JSON-Spalten in Laravel kann die Suche nach bestimmten Werten eine Herausforderung sein. Hier ist eine Lösung für das häufig auftretende Problem des Auffindens von E-Mails in einem JSON-Array, das in einer „An“-Spalte gespeichert ist.

Das Problem:

In einer „E-Mails“-Tabelle enthält eine „An“-Spalte vom Typ JSON verschachtelte Arrays, die E-Mail-Adressen darstellen. Ziel ist es, eine Sammlung aller an einen bestimmten Empfänger gesendeten E-Mails abzurufen.

Fehlgeschlagener Versuch:

Ein erster Suchversuch mit der Methode whereJsonContains von Laravel ergab keine Übereinstimmungen . Die Abfrage „übersetzt“ als:

select * from `emails` where json_contains(`to`->'$."emailAddress"."address"', '\"[email protected]\"'))
Nach dem Login kopieren

Lösung:

Der Schlüssel zu einer erfolgreichen Suche liegt im Verständnis, dass der Pfeiloperator (->) dies nicht tut mit Arrays arbeiten. Verwenden Sie für JSON-Suchen mit Arrays die folgende Syntax:

DB::table('emails')
   ->whereJsonContains('to', [['emailAddress' => ['address' => '[email protected]']]])
   ->get()
Nach dem Login kopieren

Diese Abfrage identifiziert alle E-Mails, die an die angegebene Empfängeradresse gesendet werden, korrekt und gibt sie zurück.

Das obige ist der detaillierte Inhalt vonWie suche ich nach E-Mails in einem JSON-Array in der Spalte „An' von Laravel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage