개발자 Q&A

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

2025.04.14 23:50

OCILob::truncate 함수 사용 중 오류가 발생하는 이유

목록
  • 메모리최적화전문가 1일 전 2025.04.14 23:50
  • 8
    1
제가 Oracle의 OCILob::truncate 함수를 사용하여 BLOB 데이터를 잘라내려고 하는데, 다음과 같은 오류가 발생합니다.

"ORA-22275: LOB 가 이미 truncated 됨"

이러한 오류가 발생하는 이유는 무엇이며, 이를 해결하기 위한 방법이 있을까요?

제가 현재 데이터를 다음과 같이 처리하고 있습니다.

1. BLOB 데이터를 읽어오기
2. 데이터의 일부분을 잘라내기 위해 OCILob::truncate 함수를 사용하기
3. 잘라낸 데이터를 다시 BLOB 데이터로 저장하기

이러한 프로세스 중에서 오류가 발생하는 부분은 OCILob::truncate 함수를 사용하는 부분입니다. OCILob::truncate 함수가 이미 데이터를 잘라낸 경우에 오류가 발생하는 것인지, 아니면 다른 이유가 있는지 궁금합니다.

혹시 OCILob::truncate 함수를 사용하기 전에 데이터를 다시 읽어오거나 다른 방법으로 데이터를 처리해야 하는지 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    ORA-22275 오류는 이미 LOB 데이터를 잘라내거나 삭제한 후 다시 truncate 함수를 호출했을 때 발생하는 오류입니다.

    이러한 오류를 해결하기 위해서는 이미 truncate 함수를 호출한 후 다시 truncate 함수를 호출하지 않도록 해야 합니다.

    만약에 이미 truncate 함수를 호출한 후 다시 truncate 함수를 호출해야 하는 경우, 먼저 LOB 데이터를 다시 읽어오거나 다른 방법으로 데이터를 처리해야 합니다.

    예를 들어, 다음과 같이 데이터를 다시 읽어오거나 다른 방법으로 데이터를 처리할 수 있습니다.

    #hostingforum.kr
    sql
    
    DECLARE
    
      l_blob BLOB;
    
      l_len NUMBER;
    
    BEGIN
    
      -- 데이터를 읽어오기
    
      DBMS_LOB.OPEN(l_blob, DBMS_LOB.LOB_READONLY);
    
      DBMS_LOB.GETLENGTH(l_blob, l_len);
    
      
    
      -- 데이터의 일부분을 잘라내기
    
      DBMS_LOB.TRUNCATE(l_blob, l_len / 2);
    
      
    
      -- 데이터를 다시 읽어오기
    
      DBMS_LOB.OPEN(l_blob, DBMS_LOB.LOB_READONLY);
    
      DBMS_LOB.GETLENGTH(l_blob, l_len);
    
      
    
      -- 잘라낸 데이터를 다시 BLOB 데이터로 저장하기
    
      DBMS_LOB.COPY(l_blob, l_len / 2, DBMS_LOB.LOB_MAXSIZE);
    
    END;
    
    


    이러한 예제에서, 데이터를 다시 읽어오기 위해 DBMS_LOB.OPEN 함수를 호출하고, 데이터의 길이를 다시 읽어오기 위해 DBMS_LOB.GETLENGTH 함수를 호출합니다.

    그리고 잘라낸 데이터를 다시 BLOB 데이터로 저장하기 위해 DBMS_LOB.COPY 함수를 호출합니다.

    이러한 방법으로, 이미 truncate 함수를 호출한 후 다시 truncate 함수를 호출하는 오류를 해결할 수 있습니다.

    2025-04-14 23:51

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

검색

게시물 검색