개발자 Q&A

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

2025.05.31 19:07

mysql_affected_rows 함수 이해에 필요한 도움이 필요합니다.

목록
  • 자료구조마법사 3일 전 2025.05.31 19:07
  • 7
    1
저는 최근 mysql_affected_rows 함수를 사용하여 데이터베이스에 변경을 적용했을 때 영향을 받은 행의 수를 얻으려고 합니다.
하지만 mysql_affected_rows 함수가 INSERT, UPDATE, DELETE 쿼리에서 다르게 작동하는 것을 발견했습니다.
INSERT 쿼리에서 mysql_affected_rows 함수는 1을 반환하지만, UPDATE 쿼리에서 mysql_affected_rows 함수는 변경된 행의 수를 반환합니다.
저는 mysql_affected_rows 함수가 INSERT 쿼리에서 왜 1을 반환하는지 궁금합니다.
그리고 UPDATE 쿼리에서 mysql_affected_rows 함수가 변경된 행의 수를 반환하는 이유는 무엇인지 궁금합니다.

기대하는 도움: mysql_affected_rows 함수의 동작 원리와 INSERT, UPDATE 쿼리에서 어떻게 작동하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  3일 전



    mysql_affected_rows 함수는 INSERT, UPDATE, DELETE 쿼리에서 다르게 작동하는 이유는 MySQL의 내부 로직에 따라 결정됩니다.

    INSERT 쿼리에서 mysql_affected_rows 함수가 1을 반환하는 이유는 MySQL이 INSERT 쿼리를 수행할 때, 새로운 행을 추가하는 동시에 해당 행의 ID를 자동으로 생성하는 AUTO_INCREMENT 속성을 사용할 때 발생합니다. 이 경우 MySQL은 새로운 행을 추가한 후에 해당 행의 ID를 반환합니다. 따라서 mysql_affected_rows 함수는 1을 반환하는 것입니다.

    UPDATE 쿼리에서 mysql_affected_rows 함수가 변경된 행의 수를 반환하는 이유는 MySQL이 UPDATE 쿼리를 수행할 때, 변경된 행의 수를 정확하게 계산하기 위해 내부적으로 변경된 행의 수를 추적하는 메커니즘을 사용합니다. 이 메커니즘은 UPDATE 쿼리에서 변경된 행의 수를 반환하기 위해 사용됩니다.

    따라서 mysql_affected_rows 함수의 동작 원리는 MySQL의 내부 로직에 따라 결정되며, INSERT 쿼리와 UPDATE 쿼리에서 다르게 작동하는 이유는 MySQL이 각 쿼리를 수행하는 방식이 다르기 때문입니다.

    2025-05-31 19:08

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

검색

게시물 검색