본문 바로가기
Database

오라클 데이터베이스의 LOB 관리

by 굿센스굿 2024. 12. 5.
반응형

 

오라클 데이터베이스는 LOB(Large Object) 데이터 유형을 사용하여 대용량 데이터(예: 텍스트, 이미지, 비디오 등)를 저장합니다. LOB는 일반적인 데이터와는 다른 방식으로 저장되고 관리되며, 효율적인 관리가 중요합니다. 이 글에서는 LOB의 개념, 유형, 관리 방법, 그리고 효율적인 사용을 위한 실전 예제를 살펴보겠습니다.


1. LOB란 무엇인가?

LOB는 데이터베이스 내에서 크기가 큰 데이터를 저장하기 위해 사용되는 데이터 유형입니다. 일반적으로 문자열이나 숫자 데이터와 달리, LOB는 파일, XML, 바이너리 데이터 등 대규모 데이터를 처리하는 데 적합합니다.

주요 LOB 유형

  1. CLOB(Character LOB): 텍스트 데이터를 저장하기 위한 유형으로, Unicode 문자 데이터를 지원합니다.
  2. NCLOB(National Character LOB): 멀티바이트 문자 데이터를 저장합니다.
  3. BLOB(Binary LOB): 바이너리 데이터를 저장하며, 이미지, 비디오, 오디오 파일에 주로 사용됩니다.
  4. BFILE(Binary File LOB): 데이터베이스 외부 파일을 참조하는 바이너리 데이터 유형입니다.

2. LOB 데이터 저장 방식

LOB 데이터는 크게 두 가지 방식으로 저장됩니다:

  1. 인라인 저장: LOB 데이터 크기가 작으면 테이블의 일반 행 데이터와 함께 저장됩니다.
  2. 아웃라인 저장: LOB 데이터 크기가 클 경우, 데이터는 별도의 LOB 저장소에 저장되고, 테이블 행에는 해당 데이터의 참조 정보만 저장됩니다.

LOB 데이터의 저장 방식은 ENABLE STORAGE IN ROW 또는 DISABLE STORAGE IN ROW 옵션으로 제어할 수 있습니다.


3. LOB 관리 방법

효율적인 LOB 관리를 위해 다음과 같은 주요 설정 및 방법을 활용할 수 있습니다:

(1) LOB 저장소 설정

LOB 데이터 저장소의 특성을 설정하여 성능을 최적화할 수 있습니다.

CREATE TABLE documents (  
    doc_id NUMBER PRIMARY KEY,  
    content CLOB  
) LOB (content) STORE AS SECUREFILE (  
    ENABLE STORAGE IN ROW  
    CHUNK 8K  
    CACHE  
    COMPRESS HIGH  
);  
  • SECUREFILE: 더 나은 성능과 압축 기능을 제공하는 LOB 저장 방식입니다.
  • CHUNK: 데이터를 청크 단위로 나누어 읽기/쓰기 성능을 최적화합니다.
  • CACHE: 자주 사용하는 LOB 데이터를 캐싱하여 액세스 속도를 높입니다.
  • COMPRESS: 데이터를 압축하여 저장 공간을 절약합니다.

(2) LOB 데이터 수정

LOB 데이터를 수정할 때는 DBMS_LOB 패키지를 사용하는 것이 일반적입니다.

DECLARE  
    lob_data CLOB;  
BEGIN  
    SELECT content INTO lob_data FROM documents WHERE doc_id = 1 FOR UPDATE;  
    DBMS_LOB.APPEND(lob_data, ' 추가 데이터');  
    COMMIT;  
END;  

(3) LOB 데이터 삭제

LOB 데이터 삭제 시 데이터가 실제로 제거되지 않고 공간만 비워지는 경우가 있습니다. 이를 방지하려면 SHRINK SPACE 명령을 사용합니다.

ALTER TABLE documents MODIFY LOB (content) (SHRINK SPACE);  

4. LOB 관리 실전 예제

예제 1: LOB 데이터 삽입

대량의 텍스트 데이터를 CLOB 컬럼에 삽입하는 예제입니다.

INSERT INTO documents (doc_id, content)  
VALUES (1, '이것은 LOB 데이터 예제입니다.');  

예제 2: LOB 데이터 읽기

LOB 데이터를 읽어오는 간단한 예제입니다.

DECLARE  
    lob_data CLOB;  
BEGIN  
    SELECT content INTO lob_data FROM documents WHERE doc_id = 1;  
    DBMS_OUTPUT.PUT_LINE(SUBSTR(lob_data, 1, 100)); -- 첫 100자 출력  
END;  

예제 3: BLOB 데이터를 파일로 저장

BLOB 데이터를 외부 파일로 추출하는 예제입니다.

DECLARE  
    blob_data BLOB;  
    output_file UTL_FILE.FILE_TYPE;  
BEGIN  
    SELECT binary_data INTO blob_data FROM multimedia WHERE media_id = 1;  
    output_file := UTL_FILE.FOPEN('DATA_DIR', 'output.bin', 'wb');  
    DBMS_LOB.WRITELOB_TO_FILE(blob_data, output_file);  
    UTL_FILE.FCLOSE(output_file);  
END;  

5. LOB 관리 시 주의사항

LOB 데이터 관리 시 다음 사항을 주의해야 합니다:

  1. LOB의 크기 관리: 데이터가 너무 크면 성능에 영향을 미칠 수 있으므로 적절한 압축과 캐싱을 설정해야 합니다.
  2. 네트워크 대역폭: LOB 데이터는 네트워크 전송에 많은 리소스를 소모하므로 필요 시 데이터 청크를 나눠 전송합니다.
  3. 트랜잭션 관리: LOB 데이터 수정 및 삭제는 트랜잭션 제어가 중요합니다. 대용량 데이터의 경우 자주 커밋하여 UNDO 테이블 공간 사용을 줄입니다.

6. 결론

LOB는 대규모 데이터 처리를 위한 강력한 도구이며, 오라클 데이터베이스에서 다양한 형태로 활용할 수 있습니다. 효율적인 LOB 관리와 설정은 시스템 성능 최적화 및 저장 공간 절약에 큰 도움을 줄 수 있습니다.

주요 요점 정리

  • LOB는 CLOB, NCLOB, BLOB, BFILE 등 다양한 유형을 포함합니다.
  • SECUREFILE을 사용하여 저장 공간 최적화 및 성능 개선이 가능합니다.
  • DBMS_LOB 패키지를 활용해 LOB 데이터를 효율적으로 관리할 수 있습니다.

LOB를 잘 관리한다면, 대규모 데이터의 효율적 저장과 처리를 통해 데이터베이스 운영 효율성을 크게 향상시킬 수 있습니다!

반응형