PDO 다중 쿼리: 다중 결과 세트 검색
PHP 5.3에서는 PDO_MYSQLND 드라이버에서 다중 쿼리에 대한 지원을 도입하여 다중 SELECT를 실행할 수 있습니다. 단일 호출로 쿼리합니다. 그러나 이러한 쿼리에서 결과 집합을 검색하는 것은 혼란스러울 수 있습니다.
다음 쿼리를 고려해 보세요.
$db->query("SELECT 1; SELECT 2;")
이 쿼리는 두 개의 SELECT 쿼리를 실행합니다. 그런 다음 fetchAll(PDO::FETCH_ASSOC) 메소드를 사용하여 결과 세트를 검색합니다. 그러나 이는 첫 번째 쿼리의 결과만 반환합니다.
array(1) { [0] => array(1) { [1] => string(1) "1" } }
PDOStatement::nextRowset 사용
두 번째 쿼리의 결과를 검색하려면 다음을 수행해야 합니다. PDOStatement::nextRowset 메소드를 사용하십시오. 이 방법을 사용하면 문 커서를 다음 결과 세트로 이동할 수 있습니다.
$stmt = $db->query("SELECT 1; SELECT 2;"); $stmt->nextRowset(); var_dump($stmt->fetchAll(PDO::FETCH_ASSOC));
이렇게 하면 두 번째 쿼리의 결과가 반환됩니다.
array(1) { [0] => array(1) { [2] => string(1) "2" } }
다중 FETCH 스타일
PDOStatement::nextRowset 사용의 장점은 다양한 FETCH 스타일을 사용하여 각 쿼리를 가져올 수 있다는 것입니다. 예:
$stmt = $db->query("SELECT 1; SELECT 'a';"); $stmt->nextRowset(); $first = $stmt->fetchColumn(); // fetch first column of second query $stmt->nextRowset(); $second = $stmt->fetch(PDO::FETCH_ASSOC); // fetch associative array of third query
이렇게 하면 여러 쿼리로 작업할 때 유연성이 향상됩니다.
위 내용은 단일 PDO 쿼리에서 여러 결과 세트를 검색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!