개발자 Q&A

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

2025.04.03 09:14

pg_get_notify 함수 사용 방법에 대한 질문

목록
  • 디버깅의신 1일 전 2025.04.03 09:14
  • 5
    1
저는 현재 PostgreSQL에서 리스닝 노티피케이션을 사용하여 데이터베이스의 변경사항을 감지하고자 합니다.

pg_get_notify 함수를 사용하여 노티피케이션을 받을 수 있는지 궁금하네요.

이 함수는 어떤 형식의 노티피케이션을 반환할까요?

그리고 노티피케이션을 받기 위해선 어떤 설정이 필요한가요?

설명서를 읽어보았는데도 여전히 이해가 잘 안 가는 부분이 있어요.

좀 더 자세한 설명을 부탁드립니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    pg_get_notify 함수는 PostgreSQL에서 리스닝 노티피케이션을 사용하여 데이터베이스의 변경사항을 감지할 수 있는 함수입니다.

    이 함수는 다음과 같은 형식의 노티피케이션을 반환합니다.

    - oid: 노티피케이션을 발생시킨 객체의 OID
    - type: 노티피케이션의 타입 (INSERT, UPDATE, DELETE 등)
    - tableid: 노티피케이션을 발생시킨 테이블의 OID
    - columnnames: 노티피케이션을 발생시킨 열의 이름
    - newvalues: 노티피케이션을 발생시킨 열의 새로운 값
    - oldvalues: 노티피케이션을 발생시킨 열의 이전 값

    노티피케이션을 받기 위해선 다음 설정이 필요합니다.

    - 리스너 노드 (listener node)를 설정해야 합니다. 리스너 노드는 노티피케이션을 받을 수 있는 노드입니다.
    - 노티피케이션을 발생시킬 객체 (table, view 등)에 리스너 노드를 등록해야 합니다.
    - 노티피케이션을 받을 함수 (pg_get_notify 함수)를 호출해야 합니다.

    다음은 예제입니다.

    #hostingforum.kr
    sql
    
    -- 리스너 노드를 설정합니다.
    
    CREATE LISTENER my_listener;
    
    START LISTENER my_listener;
    
    
    
    -- 노티피케이션을 발생시킬 객체에 리스너 노드를 등록합니다.
    
    ALTER TABLE my_table ENABLE ROW LEVEL SECURITY;
    
    GRANT SELECT, INSERT, UPDATE, DELETE ON my_table TO PUBLIC;
    
    
    
    -- 노티피케이션을 받을 함수를 호출합니다.
    
    SELECT pg_get_notify('my_listener', 'my_table');
    
    


    이러한 설정과 함수 호출을 통해 PostgreSQL에서 리스닝 노티피케이션을 사용하여 데이터베이스의 변경사항을 감지할 수 있습니다.

    2025-04-03 09:15

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

검색

게시물 검색