집 >데이터 베이스 >MySQL 튜토리얼 >Laravel 원시 쿼리의 매개변수를 모델과 바인딩하는 방법
모델을 사용하여 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!