> 백엔드 개발 > PHP 튜토리얼 > PHP의 `mysqli_multi_query()`에서 `mysqli_next_result()` 오류를 올바르게 처리하는 방법은 무엇입니까?

PHP의 `mysqli_multi_query()`에서 `mysqli_next_result()` 오류를 올바르게 처리하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-12-07 15:50:13
원래의
895명이 탐색했습니다.

How to Properly Handle `mysqli_next_result()` Errors in PHP's `mysqli_multi_query()`?

엄격한 표준: mysqli_next_result() mysqli_multi_query 오류

제공된 PHP 코드에서 mysqli_multi_query()를 사용하여 여러 쿼리를 실행하려는 시도 단일 데이터베이스 호출로 엄격한 표준이 실행됩니다. 오류:

mysqli_next_result(): There is no next result set. Please, call mysqli_more_results()/mysqli::more_results() to check whether to call this function/method
로그인 후 복사

이 오류를 해결하기 위해 다음 솔루션이 제공됩니다.

do {} while (mysqli_more_results($db) && mysqli_next_result($db));
로그인 후 복사

이 수정을 통해 mysqli_next_result()를 사용하기 전에 mysqli_more_results()를 확인합니다. 또한 제공된 코드에서는 결과 집합이 반환되지 않으므로 조건부 종료 대신 mysqli_affected_rows()를 확인하는 것이 더 나은 접근 방식일 수 있습니다.

mysqli_multi_query()를 사용하여 결과 집합이 있거나 없는 쿼리를 처리하는 보다 포괄적인 솔루션은 다음과 같습니다. 제공됨:

if (mysqli_multi_query($mysqli, implode(';', $queries))) {
    do {
        if ($result = mysqli_store_result($mysqli)) {
            // Process result set
        }
    } while (next($queries) && mysqli_more_results($mysqli) && mysqli_next_result($mysqli));
}

if ($mysqli_error = mysqli_error($mysqli)) {
    // Handle error
}
로그인 후 복사

또는 while 루프를 사용하여 스니펫의 "재창조된" 버전

while ((isset($multi_query) && (next($queries) && mysqli_more_results($mysqli) && mysqli_next_result($mysqli))) || (!isset($multi_query) && $multi_query = mysqli_multi_query($mysqli, implode(';', $queries)))) {
    // Process query
}

if ($mysqli_error = mysqli_error($mysqli)) {
    // Handle error
}
로그인 후 복사

이러한 스니펫은 여러 쿼리 및 결과 집합을 처리하기 위한 강력한 메커니즘을 제공하므로 더 광범위한 시나리오에 적합합니다.

위 내용은 PHP의 `mysqli_multi_query()`에서 `mysqli_next_result()` 오류를 올바르게 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿