DB/오라클

대용량 문자열 CLOB저장방법

2023. 5. 31. 22:37
목차
  1. 1. 4000Byte 이하의 CLOB 데이터 저장
  2.  
  3. 2. 4000Byte 이상의 CLOB데이터 저장

이번글에서는 CLOB데이터타입을 저장하는 방법에 대해 작성해 보았습니다.

 

두 가지 CASE로 나눠서 정리하려고 합니다.

1. 4000Byte 이하의 CLOB 데이터 저장

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
DECLARE
  l_clob CLOB;
BEGIN
  -- CLOB 열 초기화
  l_clob_data := EMPTY_CLOB();
  
  -- 데이터 삽입, CLOB COLUMN은 처음에 빈값으로 INSERT 한다.
  INSERT INTO TABLE_NAME (normal_column, clob_column) 
  VALUES (l_normal_column_value, l_clob_data) 
  RETURNING clob_column INTO l_clob_data;
  
  -- 데이터 작성
  DBMS_LOB.WRITEAPPEND(l_clob_data, LENGTH('Your CLOB Data'), 'Your CLOB Data');
  
  -- 커밋
  COMMIT;
  
  -- 결과 출력
  DBMS_OUTPUT.PUT_LINE('CLOB 데이터가 성공적으로 삽입되었습니다.');
END;
Colored by Color Scripter
cs

INSERT 할 때는 EMPTY_CLOB() 함수로 초기화 한 값을 넣어주고

RETURNING  INTO 로 CLOB컬럼을 추출한 뒤 DBMS_LOB패키지를 이용해 데이터를 작성합니다.

위 쿼리에서 녹색 부분을 잘 보시고 필요에 맞게 수정해서 사용하면 됩니다.

 

4000Byte 이하는 크게 어려움 없이 쉽게 저장할 수 있습니다.

문제는 이 밑에 설명할 4000Byte 이상의 CLOB데이터를 저장할 때입니다.

 

오라클에서 CLOB열은 일반적으로 4GB 이상의 대용량 텍스트 데이터를 저장할 수 있지만
단일 INSERT문으로는 4000Byte를 초과하는 데이터를 한 번에 저장할 수 없습니다.

 

2. 4000Byte 이상의 CLOB데이터 저장

대용량 CLOB데이터를 저장하는 방법은 'DBMS_LOB.APPEND' 서브 프로그램을 사용하여
단계적으로 삽입하는 것입니다.

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
DECLARE
  l_clob_data CLOB; --대용량 text를 잘라서 붙이 clob변수
  l_string VARCHAR2(32767); -- 임시 문자열 변수
  l_offset NUMBER := 1;        -- 문자를 자를때 사용할 cursor
  l_chunk_size NUMBER := 4000; -- 문자를 자를 길이
BEGIN
  -- CLOB 열 초기화
  l_clob_data := EMPTY_CLOB();
 
 
  INSERT INTO TABLE_NAME (normal_column, clob_column)
  VALUES (l_normal_column_value, l_clob_data)
  RETURNING clob_column INTO l_clob_data;
 
 
  -- 대용량 문자열
  l_string := 'Your large text here...'; -- 삽입할 대용량 문자열 입력
 
  
  -- 대용량 문자열을 조각으로 나누어 CLOB에 추가
  WHILE l_offset <= LENGTH(l_string) LOOP
    DBMS_LOB.WRITEAPPEND(l_clob_data, SUBSTR(l_string, l_offset, l_chunk_size));
    l_offset := l_offset + l_chunk_size;
  END LOOP;
 
  -- 커밋
  COMMIT;
 
  -- 결과 출력
  DBMS_OUTPUT.PUT_LINE('CLOB 데이터가 성공적으로 삽입되었습니다.');
END;
Colored by Color Scripter
cs

 

INSERT 부분은 위에 쿼리와 동일하지만

밑에 CLOB데이터를 작성하는 부분이 단계적으로 바뀌었습니다.

변수에 문자열을 자를 때 사용할 offset과 size를 선언하고 SUBSTR을 이용해

1 ~ 4000,  4001 ~ 8000  이렇게 일정 부분씩 잘라서 l_clob_data에 작성해 주면 됩니다.

 

위 예제를 이용해 Object를 만들어두고

업무에 이용하면 유용할 것 같습니다.

 

-끝-

 

 

 

 

  1. 1. 4000Byte 이하의 CLOB 데이터 저장
  2.  
  3. 2. 4000Byte 이상의 CLOB데이터 저장
'DB/오라클' 카테고리의 다른 글
  • View에서 Hint사용하기
  • View 조건침투(condition Pushdown)
  • 오라클 대형 데이터 TYPE
  • 업무에 사용하는 시스템테이블 정리
Interrrupt
Interrrupt
프로그래밍, 개발, IT, 일상
Interrrupt
일상의 인터럽트
Interrrupt
전체
오늘
어제
반응형
  • 분류 전체보기 (78)
    • Programing (26)
      • C# (12)
      • WPF-FrameWork (5)
      • JavaScript (7)
      • React-FrameWork (2)
    • DB (14)
      • 오라클 (14)
    • ETC (5)
      • 기타 (4)
      • 자료구조 (1)
      • 마크업 (1)
    • Tools (4)
    • 토이프로젝트 (4)
      • C# WPF로 자동매매프로그램 만들기 (4)
    • OS (2)
      • 리눅스 (1)
      • Window11 (1)
    • CS지식 (8)
      • 프론트엔드 (4)
      • 백엔드 (4)
    • 일상 (12)
      • 취미 (3)
      • 맛집 (9)
hELLO · Designed By 정상우.
Interrrupt
대용량 문자열 CLOB저장방법
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.