>데이터 베이스 >MySQL 튜토리얼 >내 MySQLi 코드가 '명령이 동기화되지 않음' 오류를 생성하는 이유는 무엇입니까?

내 MySQLi 코드가 '명령이 동기화되지 않음' 오류를 생성하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-24 21:08:25457검색

Why Does My MySQLi Code Generate a

mysqli에서 "명령이 동기화되지 않음" 오류가 발생하는 이유는 무엇입니까?

MySQL 쿼리를 동시에 실행하려고 하면 "명령이 동기화되지 않음" 오류가 발생할 수 있습니다. . 이는 MySQL 클라이언트가 새 쿼리를 실행하려고 시도하는 동안 진행 중인 쿼리에서 아직 가져올 행이 있음을 감지한 경우 발생합니다.

오류 원인

MySQL 클라이언트는 모든 행에 새 쿼리를 시작하기 전에 쿼리에서 가져옵니다. 이를 통해 데이터 손상을 방지하고 클라이언트 상태가 서버 상태와 동기화된 상태를 유지합니다.

문제 해결

1. 결과 미리 가져오기

mysqli_store_result()를 사용하여 외부 쿼리에서 모든 행을 검색할 수 있습니다. 이는 MySQL 클라이언트가 결과를 버퍼링하도록 지시하므로 간섭 없이 후속 쿼리를 실행할 수 있습니다.

2. 모든 결과 가져오기

또는 전체 결과 집합을 PHP 배열로 반환하는 mysqli_result::fetch_all()을 활용할 수도 있습니다. 이를 통해 추가 쿼리를 수행하지 않고도 배열을 반복할 수 있습니다.

특수 사례: 저장 프로시저

저장 프로시저는 각각 자체 행이 있는 여러 결과 세트를 반환할 수 있습니다. 이 시나리오를 처리하려면 mysqli_multi_query()를 사용해야 합니다. 이 메서드는 저장 프로시저를 시작하고 mysqli_next_result()를 사용하여 더 이상 결과 집합이 없을 때까지 결과 집합을 반복합니다.

계층적 데이터 모델링 대안

플랫 테이블에 계층적 데이터가 표시되는 시나리오에서 , 쿼리를 단순화하려면 다른 데이터 모델링 접근 방식을 사용하는 것이 좋습니다.

CodeIgnitor 3.0.3 mysqli_next_result()에 대한 해결 방법

CodeIgnitor 3.0.3을 사용하고 이 오류가 발생하는 개인의 경우 mysqli_driver.php 파일에 해결 방법이 있습니다. 특히 262행에서 _execute() 메서드를 다음과 같이 수정합니다.

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으로 문의하세요.