개발자 Q&A

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

2025.07.26 06:37

pg_affected_rows 함수 이해 도움 부탁드립니다.

목록
  • 뷰매니아 2일 전 2025.07.26 06:37
  • 26
    1
저는 PostgreSQL에서 INSERT, UPDATE, DELETE 쿼리를 수행한 후에 pg_affected_rows 함수를 사용하여 변경된 행의 수를 확인하고 싶습니다. 그러나 이 함수가 반환하는 값이 항상 변경된 행의 수와 일치하지 않는 것 같습니다.

예를 들어, 다음 쿼리를 수행한 후 pg_affected_rows 함수를 호출하면 어떤 값을 반환할까요?

INSERT INTO 테이블명 (열1, 열2) VALUES ('값1', '값2');

혹시 pg_affected_rows 함수의 동작 방식에 대한 설명이나 예시를 알려주실 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    pg_affected_rows 함수는 PostgreSQL에서 INSERT, UPDATE, DELETE 쿼리를 수행한 후 변경된 행의 수를 반환합니다. 그러나 이 함수는 트랜잭션 내에서만 정확한 값을 반환합니다.

    트랜잭션 내에서 INSERT, UPDATE, DELETE 쿼리를 수행한 후 pg_affected_rows 함수를 호출하면, 변경된 행의 수를 정확하게 반환합니다.

    예를 들어, 다음 쿼리를 수행한 후 pg_affected_rows 함수를 호출하면, 변경된 행의 수를 반환합니다.

    #hostingforum.kr
    sql
    
    BEGIN;
    
    INSERT INTO 테이블명 (열1, 열2) VALUES ('값1', '값2');
    
    SELECT pg_affected_rows();
    
    COMMIT;
    
    


    트랜잭션 외부에서 INSERT, UPDATE, DELETE 쿼리를 수행한 후 pg_affected_rows 함수를 호출하면, 변경된 행의 수를 반환하지 않습니다. 이 경우 pg_affected_rows 함수는 이전 트랜잭션의 변경된 행의 수를 반환합니다.

    예를 들어, 다음 쿼리를 수행한 후 pg_affected_rows 함수를 호출하면, 이전 트랜잭션의 변경된 행의 수를 반환합니다.

    #hostingforum.kr
    sql
    
    INSERT INTO 테이블명 (열1, 열2) VALUES ('값1', '값2');
    
    SELECT pg_affected_rows();
    
    


    pg_affected_rows 함수의 동작 방식은 트랜잭션 내에서만 정확한 값을 반환하는 것입니다. 트랜잭션 외부에서 호출하는 경우 이전 트랜잭션의 변경된 행의 수를 반환합니다.

    2025-07-26 06:38

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

검색

게시물 검색