개발자 Q&A

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

2025.04.27 20:15

mysqli::$affected_rows에 대한 이해

목록
  • 쿠버네티스귀신 23시간 전 2025.04.27 20:15 새글
  • 1
    1
mysqli::affected_rows() 함수는 이전 쿼리에서 처리된 행의 수를 반환합니다. 하지만 이 함수의 결과가 항상 정확한가요? 그 이유가 무엇인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  23시간 전



    mysqli::affected_rows() 함수는 이전 쿼리에서 처리된 행의 수를 반환합니다. 하지만 이 함수의 결과가 항상 정확한 것은 아닙니다.

    이 함수의 결과가 정확하지 않은 이유는 MySQL의 트랜잭션 기능 때문입니다. MySQL의 트랜잭션 기능은 여러 쿼리를 하나의 단위로 처리할 수 있습니다. 이 경우, mysqli::affected_rows() 함수는 트랜잭션의 시작점에서 끝점까지의 모든 쿼리에서 처리된 행의 수를 반환합니다.

    예를 들어, 다음과 같은 쿼리가 수행되었다고 가정해 보겠습니다.

    #hostingforum.kr
    php
    
    $db = new mysqli('localhost', 'username', 'password', 'database');
    
    
    
    $db->autocommit(false); // 트랜잭션 시작
    
    
    
    $db->query('INSERT INTO table1 VALUES (1, 2)');
    
    $db->query('INSERT INTO table2 VALUES (3, 4)');
    
    
    
    $db->commit(); // 트랜잭션 종료
    
    


    이 경우, mysqli::affected_rows() 함수는 2를 반환합니다. 하지만 실제로 처리된 행의 수는 2 + 1 = 3입니다.

    이러한 문제를 해결하기 위해, mysqli::affected_rows() 함수를 사용하기 전에 autocommit 모드를 false로 설정하고, 트랜잭션을 시작한 후에 mysqli::affected_rows() 함수를 사용하는 것이 좋습니다.

    또한, mysqli::affected_rows() 함수는 INSERT, UPDATE, DELETE 쿼리에서만 정확한 결과를 반환합니다. SELECT 쿼리에서는 항상 0을 반환합니다.

    2025-04-27 20:16

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

검색

게시물 검색