개발자 Q&A

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

2025.03.31 13:15

mysqli_stmt::fetch 함수 사용 시 오류 해결 방법을 알려주세요.

목록
  • 깃허브액션도사 1일 전 2025.03.31 13:15
  • 1
    1
제가 작성한 코드에서 mysqli_stmt::fetch 함수를 사용하여 데이터를 가져오려고 하는데, 다음과 같은 오류 메시지가 나타납니다.

php

$stmt = $mysqli->prepare("SELECT * FROM users");

$stmt->execute();

$result = $stmt->get_result();

while ($row = $result->fetch_assoc()) {

    echo $row['id'];

}



이 오류 메시지는 "mysqli_stmt::fetch는 사용할 수 없습니다." 이라고 나타납니다. 이 오류를 어떻게 해결할 수 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  1일 전



    mysqli_stmt::fetch 함수를 사용할 때는 prepare() 함수를 사용하여 쿼리를 준비한 후 execute() 함수를 사용하여 쿼리를 실행한 후에 get_result() 함수를 사용하여 결과를 가져와야 합니다.

    이러한 오류는 prepare() 함수를 사용하지 않고 execute() 함수를 사용하여 쿼리를 실행한 후 get_result() 함수를 사용하여 결과를 가져왔을 때 발생합니다.

    prepare() 함수를 사용하여 쿼리를 준비하고 execute() 함수를 사용하여 쿼리를 실행한 후 get_result() 함수를 사용하여 결과를 가져오는 코드를 다음과 같이 수정할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM users");
    
    $stmt->execute();
    
    $stmt->bind_result($id);
    
    while ($stmt->fetch()) {
    
        echo $id;
    
    }
    
    


    또는

    #hostingforum.kr
    php
    
    $stmt = $mysqli->prepare("SELECT * FROM users");
    
    $stmt->execute();
    
    $result = $stmt->get_result();
    
    while ($row = $result->fetch_assoc()) {
    
        echo $row['id'];
    
    }
    
    


    위의 두 코드 모두 prepare() 함수를 사용하여 쿼리를 준비하고 execute() 함수를 사용하여 쿼리를 실행한 후 get_result() 함수를 사용하여 결과를 가져와서 mysqli_stmt::fetch 함수를 사용하지 않습니다.

    2025-03-31 13:16

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

검색

게시물 검색