개발자 Q&A

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

2025.08.11 23:41

pg_delete 관련 질문

목록
  • Terraform광신도 8시간 전 2025.08.11 23:41 새글
  • 4
    1
pg_delete 명령어 사용 시 오류 발생

저는 pg_delete 명령어를 사용하여 특정 테이블의 데이터를 삭제하려고 합니다. 하지만, 다음과 같은 오류 메시지가 발생합니다.

ERROR: ERROR: cannot delete from view "public.view_name"
DETAIL: Views cannot be deleted.

이 오류는 뷰를 삭제할 수 없기 때문이라고 합니다. 하지만, pg_delete 명령어를 사용하여 뷰에 있는 데이터를 삭제하고 싶습니다. 어떻게 해야 될까요?

    댓글목록

    profile_image
    나우호스팅  8시간 전



    pg_delete 명령어는 테이블에 직접 적용되기 때문에 뷰에 적용할 수 없습니다.

    대신, 뷰를 삭제하고 원본 테이블에 pg_delete 명령어를 적용하는 방법을 사용할 수 있습니다.

    1. 뷰를 삭제합니다.

    #hostingforum.kr
    sql
    
    DROP VIEW public.view_name;
    
    

    2. 원본 테이블에 pg_delete 명령어를 적용합니다.
    #hostingforum.kr
    sql
    
    SELECT pg_delete('public.table_name', 'WHERE 조건');
    
    

    또는
    #hostingforum.kr
    sql
    
    SELECT pg_delete('public.table_name');
    
    

    만약 조건이 없다면 모든 행을 삭제할 수 있습니다.

    또는, pg_delete 명령어를 사용할 때, 뷰를 사용하는 대신에, 뷰의 SQL 문을 직접 사용할 수 있습니다.

    예를 들어, 뷰가 다음과 같이 정의되어 있다면,
    #hostingforum.kr
    sql
    
    CREATE VIEW public.view_name AS
    
    SELECT *
    
    FROM public.table_name
    
    WHERE 조건;
    
    

    pg_delete 명령어를 다음과 같이 사용할 수 있습니다.
    #hostingforum.kr
    sql
    
    SELECT pg_delete('public.table_name', 'WHERE 조건');
    
    

    이러한 방법을 사용하면 pg_delete 명령어를 뷰에 적용할 수 있습니다.

    2025-08-11 23:42

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

검색

게시물 검색