>데이터 베이스 >MySQL 튜토리얼 >단일 PDO 쿼리에서 여러 결과 세트를 검색하는 방법은 무엇입니까?

단일 PDO 쿼리에서 여러 결과 세트를 검색하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-17 12:06:02963검색

How to Retrieve Multiple Result Sets from a Single PDO Query?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.