명령이 동기화되지 않음: PHP에서 문제 해결
mysqli를 사용하여 PHP에서 여러 MySQL 쿼리로 작업할 때 오류가 발생할 수 있습니다. : "명령이 동기화되지 않았습니다. 지금은 이 명령을 실행할 수 없습니다." 이 오류는 버퍼링되지 않은 쿼리를 사용하기 때문에 발생합니다. 즉, 후속 쿼리를 실행하기 전에 쿼리 결과를 순차적으로 처리해야 합니다.
제공된 코드 조각에서 쿼리를 실행하여 LIKE 절을 기반으로 하는 테이블의 레코드 수($numRecords)입니다. 그러나 $data 변수는 여전히 동기화되지 않은 이전 쿼리의 결과를 참조하고 있습니다.
이 문제를 해결하려면 다음 두 가지 옵션이 있습니다.
$numRecords->execute()를 실행한 후, $data = $numRecords->get_result()를 사용하여 결과를 배열로 가져옵니다. 이렇게 하면 쿼리 결과가 저장되고 다른 쿼리를 계속 실행할 수 있습니다.
store_result( ) 실행 후 명령문 객체에 대한 메서드($numRecords->store_result()). 이렇게 하면 mysqli가 결과를 버퍼링하여 동기화 오류 없이 후속 쿼리를 실행할 수 있습니다.
다음은 get_result() 메서드를 사용하여 수정된 코드 조각입니다.
$con->query("SET NAMES 'utf8'"); $brand ="o"; $countQuery = "SELECT ARTICLE_NO FROM AUCTIONS WHERE upper(ARTICLE_NAME) LIKE % ? %"; if ($numRecords = $con->prepare($countQuery)) { $numRecords->bind_param("s", $brand); $numRecords->execute(); // Fetch the result array into $data $data = $numRecords->get_result(); $rowcount = mysqli_num_rows($data); $rows = getRowsByArticleSearch("test", "Auctions", " "); $last = ceil($rowcount/$page_rows); } else { print_r($con->error); }
참고 비쿼리(예: INSERT, UPDATE)를 실행한 다음 검색하는 쿼리를 실행하려고 하면 동기화되지 않은 명령 오류가 발생할 수도 있습니다. 먼저 연결을 닫거나 쿼리가 아닌 결과를 가져오지 않고 동일한 테이블의 데이터를 가져옵니다. 후속 쿼리를 실행하기 전에 연결을 닫았는지 또는 이전 쿼리 결과를 처리했는지 확인하세요.
위 내용은 PHP MySQL 쿼리에서 '명령이 동기화되지 않음' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!