PDO 다중 쿼리에서 다중 결과 세트 검색
PDO_MYSQLND 드라이버는 PHP 버전 5.3에서 다중 쿼리에 대한 지원을 도입했습니다. 이를 통해 사용자는 한 번에 여러 SQL 쿼리를 실행할 수 있습니다. 그러나 이러한 쿼리에서 모든 결과 집합을 검색하는 것은 어려울 수 있습니다.
문제 설명
쿼리 "SELECT 1; SELECT 2;" 두 쿼리를 모두 실행하지만 첫 번째 쿼리의 결과 집합만 반환됩니다. 두 번째 결과 집합은 삭제된 것으로 보입니다.
해결책
여러 결과 집합을 검색하려면 PDOStatement::nextRowset 메서드를 사용해야 합니다. 이 메서드는 커서를 다음 행 집합의 시작 부분으로 이동합니다. 첫 번째 쿼리 후 nextRowset을 호출하면 사용자는 두 번째 쿼리의 결과 집합에 액세스할 수 있습니다.
$stmt = $db->query("SELECT 1; SELECT 2;"); $stmt->nextRowset(); var_dump($stmt->fetchAll(PDO::FETCH_ASSOC));
이렇게 하면 두 번째 쿼리에 대한 결과 집합이 반환됩니다.
장점 및 단점
이 구현을 통해 다양한 FETCH 스타일을 사용하여 각 쿼리의 결과를 가져올 수 있습니다. 그러나 단순히 하나의 배열 아래에 있는 모든 결과 집합을 반환하는 구현보다 더 복잡할 수 있습니다. 그럼에도 불구하고 여러 결과를 유연하게 처리하는 능력은 일부 시나리오에서 유용할 수 있습니다.
위 내용은 단일 PDO MySQL 쿼리에서 여러 결과 세트를 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!