>백엔드 개발 >PHP 튜토리얼 >PHP MySQL 쿼리에서 '명령이 동기화되지 않음' 오류를 수정하는 방법은 무엇입니까?

PHP MySQL 쿼리에서 '명령이 동기화되지 않음' 오류를 수정하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-19 10:25:10425검색

How to Fix

명령이 동기화되지 않음: PHP에서 문제 해결

mysqli를 사용하여 PHP에서 여러 MySQL 쿼리로 작업할 때 오류가 발생할 수 있습니다. : "명령이 동기화되지 않았습니다. 지금은 이 명령을 실행할 수 없습니다." 이 오류는 버퍼링되지 않은 쿼리를 사용하기 때문에 발생합니다. 즉, 후속 쿼리를 실행하기 전에 쿼리 결과를 순차적으로 처리해야 합니다.

제공된 코드 조각에서 쿼리를 실행하여 LIKE 절을 기반으로 하는 테이블의 레코드 수($numRecords)입니다. 그러나 $data 변수는 여전히 동기화되지 않은 이전 쿼리의 결과를 참조하고 있습니다.

이 문제를 해결하려면 다음 두 가지 옵션이 있습니다.

  1. 결과 배열 가져오기:

$numRecords->execute()를 실행한 후, $data = $numRecords->get_result()를 사용하여 결과를 배열로 가져옵니다. 이렇게 하면 쿼리 결과가 저장되고 다른 쿼리를 계속 실행할 수 있습니다.

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

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