개발자 Q&A

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

2025.07.19 14:23

mysqli::$affected_rows를 사용하여 데이터베이스에서 변경된 행의 수를 구하는 방법에 대해 질문이 있습니다.

목록
  • HTTP전문가 18시간 전 2025.07.19 14:23 새글
  • 8
    1
mysqli::$affected_rows를 사용하여 데이터베이스에서 변경된 행의 수를 구하는 방법은 무엇입니까?
mysqli::$affected_rows를 사용하여 데이터베이스에서 변경된 행의 수를 구할 때, 어떤 경우에 0이 반환되는지 궁금합니다.
mysqli::$affected_rows를 사용하여 데이터베이스에서 변경된 행의 수를 구할 때, 어떤 경우에 -1이 반환되는지 궁금합니다.

    댓글목록

    profile_image
    나우호스팅  18시간 전



    mysqli::$affected_rows는 MySQLi 객체의 메소드 중 하나로, 마지막 쿼리에서 변경된 행의 수를 반환합니다.

    1. 데이터베이스에서 변경된 행의 수를 구하는 방법은 다음과 같습니다.

    - MySQLi 객체를 생성한 후, 쿼리를 실행합니다.
    - 쿼리 실행 후, mysqli::$affected_rows를 호출하여 변경된 행의 수를 반환합니다.

    예시:

    #hostingforum.kr
    php
    
    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    $mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition");
    
    echo $mysqli->affected_rows; // 변경된 행의 수를 출력합니다.
    
    


    2. mysqli::$affected_rows가 0을 반환하는 경우는 다음과 같습니다.

    - 쿼리가 실행되지 않은 경우
    - 쿼리가 성공적으로 실행되었지만 변경된 행이 없는 경우
    - 쿼리가 실패한 경우 (예: 권한 오류, 데이터베이스 오류)

    예시:
    #hostingforum.kr
    php
    
    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    $mysqli->query("SELECT * FROM table_name WHERE condition"); // 쿼리가 실행되지 않음
    
    echo $mysqli->affected_rows; // 0을 반환합니다.
    
    
    
    $mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'false'"); // 변경된 행이 없음
    
    echo $mysqli->affected_rows; // 0을 반환합니다.
    
    
    
    $mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'invalid'"); // 권한 오류
    
    echo $mysqli->affected_rows; // 0을 반환합니다.
    
    


    3. mysqli::$affected_rows가 -1을 반환하는 경우는 다음과 같습니다.

    - 쿼리가 실행되지 않은 경우 (예: 쿼리 실행 전)
    - 쿼리가 실패한 경우 (예: 권한 오류, 데이터베이스 오류)

    예시:
    #hostingforum.kr
    php
    
    $mysqli = new mysqli("localhost", "username", "password", "database");
    
    echo $mysqli->affected_rows; // -1을 반환합니다.
    
    
    
    $mysqli->query("UPDATE table_name SET column_name = 'value' WHERE condition = 'invalid'"); // 권한 오류
    
    echo $mysqli->affected_rows; // -1을 반환합니다.
    
    

    2025-07-19 14:24

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

검색

게시물 검색