MySQLi에서 "명령이 동기화되지 않음" 오류가 발생하는 이유는 무엇입니까?
MySQL 클라이언트에서는 새 쿼리 실행을 허용하지 않습니다. 진행 중인 쿼리에서 가져올 행이 아직 남아 있는 동안 "동기화되지 않은 명령"에 대한 자세한 내용은 일반적인 오류에 대한 MySQL 문서를 참조하세요.
해결책:
mysqli_store_result()를 사용하여 외부 쿼리. 이렇게 하면 MySQL 클라이언트에서 버퍼링되므로 서버는 앱이 전체 결과 세트를 가져왔다고 믿습니다. 그런 다음 현재 버퍼링된 외부 결과 집합에서 행을 가져오는 루프 내에서도 더 많은 쿼리를 실행할 수 있습니다.
또는 전체 결과 집합을 PHP 배열로 반환하는 mysqli_result::fetch_all()을 사용하세요. 그런 다음 해당 배열을 반복할 수 있습니다.
저장 프로시저의 특수 사례:
저장 프로시저는 각각 자체 행 집합이 있는 여러 결과 집합을 반환할 수 있습니다. 그러므로 mysqli_multi_query()를 사용하고 mysqli_next_result()가 더 이상 추가 결과 세트를 반환하지 않을 때까지 반복해야 합니다. 이는 저장 프로시저에 단일 결과 집합만 있는 경우에도 MySQL 프로토콜을 충족하는 데 필요합니다.
참고:
중첩 쿼리는 계층 구조를 나타내는 데 자주 사용됩니다. 하지만 보다 간단한 쿼리를 사용하는 대체 방법이 더 나을 수도 있습니다. 더 쉽게 쿼리할 수 있도록 데이터를 다른 방식으로 저장하는 것을 고려해 보세요.
위 내용은 MySQLi에서 '명령이 동기화되지 않음' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!