>데이터 베이스 >MySQL 튜토리얼 >Laravel 원시 쿼리의 매개변수를 모델과 바인딩하는 방법

Laravel 원시 쿼리의 매개변수를 모델과 바인딩하는 방법

DDD
DDD원래의
2024-11-15 01:31:02829검색

How to Bind Parameters in Laravel Raw Queries with a Model

모델을 사용하여 Laravel 원시 쿼리의 매개변수 바인딩

Laravel에서 모델에 사용되는 원시 DB 쿼리에 매개변수를 바인딩하는 것은 까다로울 수 있습니다. 그러나 도움이 될 수 있는 해결 방법은 다음과 같습니다.

문제:

다음 쿼리는 명명 및 위치 혼합으로 인해 "잘못된 매개 변수 번호" 오류와 함께 실패합니다. 매개변수:

$query = DB::raw("... :lat, :lng, (calc) AS ...")->having("calc", "<", :radius);

해결책:

setBindings() 메서드를 활용하여 쿼리 바인딩을 수동으로 설정하고 혼합된 매개변수를 재정의합니다. 문제:

$query = DB::raw("... ?, ?, (calc) AS ...")->having("calc", "<", "?");
$query->setBindings([$lat, $lng, $radius]);

설명:

DB::raw() 문은 물음표를 위치 매개변수로 사용하므로 대신 setBindings()를 사용하여 설정할 수 있습니다. 명명된 바인딩. 이 접근 방식을 사용하면 매개변수 혼합에 대한 걱정 없이 쿼리 빌더의 원활한 인터페이스를 사용할 수 있습니다.

위 내용은 Laravel 원시 쿼리의 매개변수를 모델과 바인딩하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.