개발자 Q&A

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

2025.03.31 21:09

OCILob::append 관련 질문

목록
  • TCP/IP장인 1일 전 2025.03.31 21:09
  • 3
    1
저는 Oracle PL/SQL에서 LOB 데이터를 처리하는 과정에서 OCILob::append 메서드에 대한 이해가 부족합니다.

LOB 데이터를 추가할 때 OCILob::append 메서드를 사용하면 LOB 데이터의 길이를 늘려야 하는지, 아니면 LOB 데이터의 끝에만 추가할 수 있는지 궁금합니다.

다음과 같은 예제를 사용했을 때 OCILob::append 메서드가 어떻게 동작하는지 설명해주시면 감사하겠습니다.

plsql

DECLARE

  l_lob OCILob.BLOB;

  l_offset NUMBER := 0;

  l_amount NUMBER := 100;

  l_buffer RAW(100) := 'Hello, World!';

BEGIN

  l_lob := OCILob.LobLocate(l_lob, 1);

  

  -- OCILob::append 메서드를 사용할 때

  DBMS_Lob.Append(l_lob, l_buffer);

  

  -- OCILob::write 메서드를 사용할 때

  DBMS_Lob.Write(l_lob, l_amount, l_offset, l_buffer);

END;



OCILob::append 메서드를 사용할 때는 LOB 데이터의 길이를 늘려야 하는지, 아니면 LOB 데이터의 끝에만 추가할 수 있는지 알려주시면 감사하겠습니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    OCILob::append 메서드는 LOB 데이터의 끝에만 추가할 수 있습니다.

    DBMS_Lob.Append(l_lob, l_buffer);와 DBMS_Lob.Write(l_lob, l_amount, l_offset, l_buffer);의 차이점은 다음과 같습니다.

    - DBMS_Lob.Append(l_lob, l_buffer); : LOB 데이터의 끝에만 추가합니다.
    - DBMS_Lob.Write(l_lob, l_amount, l_offset, l_buffer); : LOB 데이터의 특정 위치에 추가합니다.

    따라서, OCILob::append 메서드를 사용할 때는 LOB 데이터의 길이를 늘려야 하는 것이 아닙니다.

    예제를 살펴보겠습니다.

    plsql
    
    DECLARE
    
      l_lob OCILob.BLOB;
    
      l_offset NUMBER := 0;
    
      l_amount NUMBER := 100;
    
      l_buffer RAW(100) := 'Hello, World!';
    
    BEGIN
    
      l_lob := OCILob.LobLocate(l_lob, 1);
    
    
    
      -- OCILob::append 메서드를 사용할 때
    
      DBMS_Lob.Append(l_lob, l_buffer);
    
    
    
      -- LOB 데이터의 길이를 확인합니다.
    
      DBMS_Output.Put_Line('LOB 데이터의 길이 : ' || DBMS_Lob.GetLength(l_lob));
    
    END;
    
    


    위 예제를 실행하면 LOB 데이터의 길이가 증가하지 않음을 확인할 수 있습니다.

    plsql
    
    DECLARE
    
      l_lob OCILob.BLOB;
    
      l_offset NUMBER := 0;
    
      l_amount NUMBER := 100;
    
      l_buffer RAW(100) := 'Hello, World!';
    
    BEGIN
    
      l_lob := OCILob.LobLocate(l_lob, 1);
    
    
    
      -- LOB 데이터의 길이를 확인합니다.
    
      DBMS_Output.Put_Line('LOB 데이터의 길이 : ' || DBMS_Lob.GetLength(l_lob));
    
    
    
      -- OCILob::append 메서드를 사용할 때
    
      DBMS_Lob.Append(l_lob, l_buffer);
    
    
    
      -- LOB 데이터의 길이를 확인합니다.
    
      DBMS_Output.Put_Line('LOB 데이터의 길이 : ' || DBMS_Lob.GetLength(l_lob));
    
    END;
    
    


    위 예제를 실행하면 LOB 데이터의 길이가 증가하지 않음을 확인할 수 있습니다.

    따라서, OCILob::append 메서드를 사용할 때는 LOB 데이터의 길이를 늘려야 하는 것이 아닙니다.

    2025-03-31 21:10

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

검색

게시물 검색