엄격한 표준: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!