PDO에서는 매개변수 배열을 사용하여 LIMIT 절이 포함된 쿼리를 실행하는 것이 어려울 수 있습니다.
다음 코드를 고려하세요.
$sql = "SELECT * FROM table WHERE id LIKE CONCAT('%', :id, '%') LIMIT :limit1, :limit2"; $stmt = $pdo->prepare($sql); $stmt->execute($array); // Doesn't work
편의상 배열 입력을 사용하는 것이 바람직하지만 :limit1 및 :limit2 매개변수는 개별적으로 바인딩되지 않으면 작동하지 않습니다. :
$stmt->bindParam(':limit1', $limit1, PDO::PARAM_INT); $stmt->bindParam(':limit2', $limit2, PDO::PARAM_INT); $stmt->execute(); // Still doesn't work
문제는 PDO의 기본 설정인 PDO::ATTR_EMULATE_PREPARES가 true인 데 있습니다. 이 설정을 사용하면 PHP가 기본 MySQL 준비된 문을 사용하는 대신 준비된 문을 에뮬레이션하게 되므로 LIMIT 매개변수의 적절한 바인딩이 방해됩니다.
이 문제를 해결하려면 속성을 false로 설정하여 에뮬레이션을 비활성화하세요.
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
에뮬레이션이 비활성화되면 배열 입력을 사용하여 쿼리를 올바르게 실행할 수 있습니다.
$stmt = $pdo->prepare($sql); $stmt->execute($array); // Works!
에뮬레이션을 비활성화하면 기본적으로 성능에 영향을 미칠 수 있습니다. 준비된 문은 특정 시나리오에서 더 효율적입니다. 그러나 동적 LIMIT 절이 필요한 쿼리의 경우 가장 안정적인 솔루션입니다.
위 내용은 LIMIT 절을 사용하여 PDO 매개변수 배열을 전달하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!