>데이터 베이스 >MySQL 튜토리얼 >중첩 쿼리를 사용할 때 MySQLi에서 '명령이 동기화되지 않음' 오류를 해결하는 방법은 무엇입니까?

중첩 쿼리를 사용할 때 MySQLi에서 '명령이 동기화되지 않음' 오류를 해결하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-08 07:29:10560검색

How to Resolve the

오류: MySQLi를 사용하는 동안 "명령이 동기화되지 않았습니다"

문제:

여러 MySQLi 쿼리를 동시에 실행하려고 하면 "명령이 동기화되지 않음" 오류가 발생합니다. 중첩 쿼리는 계층적 데이터를 검색합니다.

원인:

MySQL에서는 진행 중인 쿼리의 행이 남아 있는 동안 새 쿼리 실행을 허용하지 않습니다. 가져오지 않았습니다.

해결책:

옵션 1: mysqli_store_result() 사용

$result = mysqli_store_result($db);
// Execute subsequent queries

이렇게 하면 MySQL 클라이언트, 다중 쿼리 가능 실행됩니다.

옵션 2: mysqli_result::fetch_all() 사용

$result = mysqli_query($db, $sql);
$data = mysqli_fetch_all($result, MYSQLI_ASSOC);
// Execute subsequent queries

이렇게 하면 전체 결과 집합이 배열로 반환되므로 여러 쿼리를 수행할 수 있습니다.

고려 사항:

중첩 쿼리는 계층적 데이터 저장을 나타냅니다. mysqli_next_result()를 사용하여 저장 프로시저의 여러 결과 세트를 처리하려면 대체 데이터 모델이나 CodeIgnitor와 같은 프레임워크 사용을 고려하세요.

CodeIgnitor 구현:

// Edit code in system/database/drivers/mysqli/mysqli_driver.php
protected function _execute($sql)
{
    $results = $this->conn_id->query($this->_prep_query($sql));
    @mysqli_next_result($this->conn_id); // Fix 'command out of sync' error
    return $results;
}

위 내용은 중첩 쿼리를 사용할 때 MySQLi에서 '명령이 동기화되지 않음' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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