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