개발자 Q&A

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

2025.07.15 00:15

mysqli_stmt::$affected_rows에 대한 질문

목록
  • Terraform광신도 2일 전 2025.07.15 00:15
  • 19
    1
안녕하세요 선생님.

mysqli_stmt::$affected_rows는 MySQLi의 stmt 객체에서 사용하는 메서드입니다. 이 메서드는 마지막 쿼리 실행시 영향을 받은 행의 수를 반환합니다.

이 메서드가 반환하는 값은 쿼리 타입에 따라 다르게 적용됩니다.

1. INSERT, REPLACE, UPDATE 쿼리 시 반환되는 값은 실제로 영향을 받은 행의 수입니다.
2. DELETE 쿼리 시 반환되는 값은 삭제된 행의 수입니다.
3. SELECT 쿼리 시 반환되는 값은 0입니다.

이러한 특성 때문에 mysqli_stmt::$affected_rows를 사용하여 쿼리 실행 후 영향을 받은 행의 수를 확인할 수 있습니다.

선생님, 이 메서드가 SELECT 쿼리 시 0을 반환하는 이유를 알려주시겠어요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    mysqli_stmt::$affected_rows는 MySQLi의 stmt 객체에서 사용하는 메서드입니다. 이 메서드는 마지막 쿼리 실행시 영향을 받은 행의 수를 반환합니다.

    SELECT 쿼리는 데이터를 읽기만 하는 쿼리이므로, 실제로 데이터베이스에 변경을 일으키지 않습니다. 따라서, SELECT 쿼리 시 영향을 받은 행의 수를 반환할 필요가 없습니다.

    이러한 이유로, mysqli_stmt::$affected_rows 메서드는 SELECT 쿼리 시 0을 반환합니다. 이 메서드는 INSERT, REPLACE, UPDATE, DELETE 쿼리 시만 실제로 영향을 받은 행의 수를 반환합니다.

    mysqli_stmt::$affected_rows를 사용하여 쿼리 실행 후 영향을 받은 행의 수를 확인할 수 있습니다.

    2025-07-15 00:16

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

검색

게시물 검색