집 >데이터 베이스 >MySQL 튜토리얼 >PDO의 LIMIT 절을 사용하여 배열 매개변수를 바인딩할 수 있습니까?
PDO에서 LIMIT 절을 사용하여 배열 매개변수 전달
PHP에서 PDOStatement 클래스는 매개변수화된 값으로 SQL 쿼리를 실행하는 방법을 제공합니다. 그러나 LIMIT 절을 사용하는 경우에는 BindParam() 메서드를 사용하는 매개 변수 바인딩이 작동하지 않습니다.
이 문제를 해결하려면 다음 해결 방법을 고려하세요.
<code class="php">$sql = "SELECT * FROM table WHERE id LIKE CONCAT('%', :id, '%') LIMIT :offset, :limit"; $stmt = $pdo->prepare($sql); // Turn off PDO emulation of prepared statements for MySQL $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false); $array = [':id' => 5]; // Bind the LIMIT parameters $stmt->bindParam(':offset', $limit1, PDO::PARAM_INT); $stmt->bindParam(':limit', $limit2, PDO::PARAM_INT); // Execute the query $stmt->execute($array); $results = $stmt->fetchAll();</code>
PDO 에뮬레이션을 비활성화하여 준비된 문(MySQL의 기본값)을 사용하면 LIMIT 절 내에서 매개변수화된 값을 사용할 수 있습니다. 이 방법을 사용하면 지정된 매개변수를 사용하여 쿼리가 올바르게 실행될 수 있습니다.
에뮬레이션을 끄면 성능에 영향을 미칠 수 있습니다. 자세한 내용은 PDO MySQL: PDO::ATTR_EMULATE_PREPARES 사용 여부
문서를 참조하세요.위 내용은 PDO의 LIMIT 절을 사용하여 배열 매개변수를 바인딩할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!