개발자 Q&A

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

2025.08.05 16:08

pg_lo_unlink 함수에 대한 질문

목록
  • Bootstrap고수 15시간 전 2025.08.05 16:08 새글
  • 1
    1
저는 PostgreSQL에서 데이터베이스에 저장된 Large Object(Large Object, LO)을 삭제하기 위해 pg_lo_unlink 함수를 사용하려고 합니다.

pg_lo_unlink 함수의 사용법과, LO를 삭제할 수 있는 권한을 얻는 방법을 알려주실 수 있을까요?

또한, LO를 삭제한 후, 그 LO를 다시 사용할 수 있는 방법은 무엇인가요?

그리고, pg_lo_unlink 함수가 실패할 경우, 에러 메시지를 어떻게 처리할 수 있는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  15시간 전



    pg_lo_unlink 함수는 PostgreSQL에서 데이터베이스에 저장된 Large Object(Large Object, LO)를 삭제하는 함수입니다.

    pg_lo_unlink 함수의 사용법은 다음과 같습니다.

    #hostingforum.kr
    sql
    
    pg_lo_unlink(oid);
    
    


    oid는 LO의 OID입니다.

    LO를 삭제할 수 있는 권한을 얻는 방법은 다음과 같습니다.

    #hostingforum.kr
    sql
    
    GRANT ALL PRIVILEGES ON LARGE OBJECTS TO ROLE명;
    
    


    ROLE명은 삭제 권한을 부여받을 역할 이름입니다.

    LO를 삭제한 후, 그 LO를 다시 사용할 수 있는 방법은 다음과 같습니다.

    1. LO를 삭제한 후, 새로운 LO를 생성합니다.

    #hostingforum.kr
    sql
    
    pg_lo_create();
    
    


    2. 새로운 LO의 OID를 얻어내고, 그 OID를 사용하여 LO를 삭제합니다.

    #hostingforum.kr
    sql
    
    oid := pg_lo_create();
    
    pg_lo_unlink(oid);
    
    


    pg_lo_unlink 함수가 실패할 경우, 에러 메시지를 처리하는 방법은 다음과 같습니다.

    1. 에러 메시지를 확인하여 LO의 OID가 존재하지 않는지 확인합니다.

    #hostingforum.kr
    sql
    
    SELECT pg_lo_unlink(oid);
    
    IF pg_lo_unlink(oid) = 0 THEN
    
        -- LO의 OID가 존재하지 않습니다.
    
    END IF;
    
    


    2. 에러 메시지를 확인하여 LO 삭제 권한이 없는지 확인합니다.

    #hostingforum.kr
    sql
    
    SELECT pg_lo_unlink(oid);
    
    IF pg_lo_unlink(oid) = 0 THEN
    
        -- LO 삭제 권한이 없습니다.
    
    END IF;
    
    


    3. 에러 메시지를 확인하여 LO가 이미 삭제된 경우입니다.

    #hostingforum.kr
    sql
    
    SELECT pg_lo_unlink(oid);
    
    IF pg_lo_unlink(oid) = 0 THEN
    
        -- LO가 이미 삭제된 경우입니다.
    
    END IF;
    
    

    2025-08-05 16:09

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

검색

게시물 검색