개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.07.29 01:49

mysqli::more_results() 함수 이해를 도와주세요

목록
  • 코딩테스트러버 1일 전 2025.07.29 01:49
  • 10
    1
저는 PHP에서 MySQL 데이터베이스와 상호작용하는 코드를 작성 중인데, mysqli::more_results() 함수를 사용하여 데이터베이스에서 쿼리 결과를 처리하는 방법을 이해하지 못하고 있습니다.

mysqli::more_results() 함수는 쿼리 결과가 더 있으면 true를 반환하고, 없으면 false를 반환하는 함수입니다. 그러나 이 함수를 사용하기에 앞서, 이전 쿼리 결과를 처리해야 한다는 것을 어떻게 알 수 있을까요? 이전 쿼리 결과를 처리하는 방법을 알려주세요.

예를 들어, 다음 코드를 작성했습니다.

php

$conn = new mysqli($host, $user, $password, $db);

if ($conn->query("SELECT * FROM 테이블1") && $conn->query("SELECT * FROM 테이블2")) {

    echo "쿼리 실행 성공";

} else {

    echo "쿼리 실행 실패";

}



이 코드에서, 두 쿼리가 실행되었을 때, mysqli::more_results() 함수를 사용하여 이전 쿼리 결과를 처리해야 한다는 것을 어떻게 알 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysqli::more_results() 함수는 이전 쿼리 결과를 처리하기 전에 사용할 수 없습니다.

    이러한 경우, 이전 쿼리 결과를 처리하기 전에 mysqli::next_result() 함수를 사용하여 이전 쿼리 결과를 처리해야 합니다.

    예를 들어, 다음 코드를 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $conn = new mysqli($host, $user, $password, $db);
    
    if ($conn->query("SELECT * FROM 테이블1")) {
    
        $result1 = $conn->store_result();
    
        while ($row = $result1->fetch_assoc()) {
    
            // 결과 처리
    
        }
    
        $result1->free();
    
    }
    
    
    
    if ($conn->next_result()) {
    
        $result2 = $conn->store_result();
    
        while ($row = $result2->fetch_assoc()) {
    
            // 결과 처리
    
        }
    
        $result2->free();
    
    } else {
    
        // 이전 쿼리 결과를 처리하지 못했습니다.
    
    }
    
    


    또는, mysqli::multi_query() 함수를 사용하여 여러 쿼리를 한번에 실행할 수 있습니다.

    #hostingforum.kr
    php
    
    $conn = new mysqli($host, $user, $password, $db);
    
    if ($conn->multi_query("SELECT * FROM 테이블1; SELECT * FROM 테이블2")) {
    
        do {
    
            if ($result = $conn->store_result()) {
    
                while ($row = $result->fetch_assoc()) {
    
                    // 결과 처리
    
                }
    
                $result->free();
    
            }
    
        } while ($conn->next_result());
    
    } else {
    
        // 쿼리 실행 실패
    
    }
    
    

    2025-07-29 01:50

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 39,976건 / 7 페이지

검색

게시물 검색