Heim > Datenbank > MySQL-Tutorial > Hauptteil

Wie gehe ich mit Bindungsparametern in Laravel Raw DB-Abfragen für Modelle um?

Mary-Kate Olsen
Freigeben: 2024-11-19 02:58:02
Original
342 Leute haben es durchsucht

How to Handle Binding Parameters in Laravel Raw DB Queries on Models?

Bindungsparameter in Laravel-Roh-DB-Abfragen für Modelle

Bei der Arbeit mit Roh-DB-Abfragen in Laravel für Modelle können Bindungsparameter eine Herausforderung darstellen . Dieses Problem tritt auf, wenn eine Kombination aus benannten und Positionsparametern verwendet wird, und führt zu dem Fehler „Ungültige Parameternummer: benannte und Positionsparameter gemischt.“

Um dieses Problem zu beheben, ziehen Sie die folgende Lösung in Betracht:

  1. Ersetzen Sie die benannten Parameter in der Roh-DB-Abfrage durch Fragezeichen (?).
  2. Verwenden Sie die setBindings()-Methode, um die Parameterwerte an die Abfrage zu binden. Die Reihenfolge der Werte im an setBindings() übergebenen Array sollte mit der Reihenfolge der Fragezeichen in der Abfrage übereinstimmen.
$property = Property::select(
    DB::raw("title, lat, lng, ( 
        3959 * acos( 
            cos( radians(  ?  ) ) *
            cos( radians( lat ) ) * 
            cos( radians( lng ) - radians(?) ) + 
            sin( radians(  ?  ) ) *
            sin( radians( lat ) ) 
        )
   ) AS distance")
)
->having("distance", "<", "?")
->orderBy("distance")
->take(20)
->setBindings([$lat, $lng, $lat, $radius])
->get();
Nach dem Login kopieren

Durch die Verwendung der setBindings()-Methode können Parameterwerte an gebunden werden Die Abfrage ermöglicht die Ausführung von Roh-DB-Abfragen, die eine Parametrisierung erfordern.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Bindungsparametern in Laravel Raw DB-Abfragen für Modelle um?. 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