개발자 Q&A

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

2025.08.15 07:04

mysqli_stmt::next_result 함수에 대한 질문

목록
  • JetpackCompose마… 8시간 전 2025.08.15 07:04 새글
  • 8
    1
제가 mysqli_stmt::next_result 함수를 사용하여 여러 개의 쿼리를 실행시키려고 하는데,
stmt->next_result()를 호출한 후에는 stmt->fetch()를 사용할 수 없다는 것을 알게되었습니다.

이러한 상황에서 stmt->next_result()와 stmt->fetch()를 동시에 사용할 수 있는 방법이 있는지 알고 싶습니다.

해당 함수의 동작 원리에 대한 설명과 함께 조언을 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  8시간 전



    mysqli_stmt::next_result() 함수는 이전 쿼리의 결과를 무시하고 다음 쿼리의 결과를 반환합니다. 이 함수를 호출한 후 stmt->fetch()를 사용하면 오류가 발생합니다. 이는 mysqli_stmt::next_result() 함수가 stmt->fetch() 함수와 동시에 사용할 수 없기 때문입니다.

    mysqli_stmt::next_result() 함수의 동작 원리는 다음과 같습니다.

    1. 이전 쿼리의 결과를 무시합니다.
    2. 다음 쿼리의 결과를 반환합니다.
    3. stmt->fetch() 함수를 사용할 수 없습니다.

    이를 해결하기 위한 방법은 다음과 같습니다.

    1. stmt->next_result() 함수를 호출한 후 stmt->free_result() 함수를 호출하여 이전 쿼리의 결과를 삭제합니다.
    2. stmt->next_result() 함수를 호출한 후 stmt->store_result() 함수를 호출하여 다음 쿼리의 결과를 저장합니다.
    3. stmt->next_result() 함수를 호출한 후 stmt->fetch_all() 함수를 호출하여 다음 쿼리의 결과를 모두 가져옵니다.

    예를 들어, 다음과 같이 쿼리를 실행하고 결과를 가져올 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM table1");
    
    $stmt->execute();
    
    $stmt->store_result();
    
    
    
    $stmt = $mysqli->prepare("SELECT * FROM table2");
    
    $stmt->execute();
    
    $stmt->store_result();
    
    
    
    $result = $stmt->fetch_all(MYSQLI_ASSOC);
    
    


    또는

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM table1");
    
    $stmt->execute();
    
    $stmt->free_result();
    
    
    
    $stmt = $mysqli->prepare("SELECT * FROM table2");
    
    $stmt->execute();
    
    $stmt->store_result();
    
    
    
    $result = $stmt->fetch_all(MYSQLI_ASSOC);
    
    


    이러한 방법으로 stmt->next_result() 함수와 stmt->fetch() 함수를 동시에 사용할 수 있습니다.

    2025-08-15 07:05

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

검색

게시물 검색