ORACLE BULK SQL 사용예

2020.10.09 21:52

졸리운_곰 조회 수:33

BULK SQL 사용예

대량의 데이터를 load 하거나 update(delete) 할 때 일반적으로 사용하는 LOOP 문보다 성능이 수십배 이상 좋은 방법이 BULK SQL 을 사용하는 방법이다. 

일반적인 LOOP 문 안에 있는 SQL 은 매 LOOP 마다 1회씩 수행된다. LOOP 가 100만개이면 100만번의 SQL 수행이 발생되는 것이다. 반면에 BULK SQL 을 사용하면 LOOP 없이 1번의 SQL 수행으로 처리할 수 있다.

BULK SQL 처리를 위해 오라클 PL/SQL 에서는 FORALL 과 BULK COLLECT INTO 라는 이라는 예약어를 사용한다. FORALL 은 PL/SQL 이 DML 문장을 SQL 엔진에게 보내는데 사용되고, BULK COLLECT INTO 는 SQL 수행결과 데이터셋을 PL/SQL 엔진에게 보낸다.

BULK SQL 은 MULTI ROW 집합을 한번에 처리하기 때문에 ARRAY 처리가 쉬운 TABLE DATATYPE 같은 collection type 이 주로 사용된다.

BULK SQL 로 수백만건을 한번에 처리할 수도 있지만, 이렇게 하면 PGA 소모가 크기 때문에 1000 ~ 100000 건 단위로 나누어서 작업하는 것이 좋다. 이를 위해 LIMIT 이라는 예약어를 사용한다. 

 

<참고> BULK SQL 에 대해서 자세히 공부하려면 아래의 링크를 보세요.

http://docs.oracle.com/cd/E11882_01/appdev.112/e25519/tuning.htm#BABFHGHI

 

---------------------

BULK SQL 사용예

---------------------

DROP TABLE SH.SALES2;

CREATE TABLE SH.SALES2 AS 

SELECT * FROM SH.SALES

WHERE 1=2;

 

CREATE OR REPLACE PROCEDURE P_BULK_INSERT_TEST IS

 

  CURSOR sales_cur IS

                         SELECT  PROD_ID,

                                 CUST_ID,

                                 TIME_ID,

                                 CHANNEL_ID,

                                 PROMO_ID,

                                 QUANTITY_SOLD,

                                 AMOUNT_SOLD

                         FROM    SH.SALES;

 

  TYPE SALES_TBL_TYPE IS TABLE OF sales_cur%ROWTYPE INDEX BY BINARY_INTEGER;

  SALES_TBL SALES_TBL_TYPE;

 

BEGIN

 

  OPEN sales_cur;

  

  LOOP 

    FETCH sales_cur BULK COLLECT INTO  sales_tbl LIMIT 1000-- PGA 소모를 작게 유지하기 위해 1000건씩만 처리

 

    --각종 계산은 여기에서

    FOR i IN sales_tbl.FIRST..sales_tbl.LAST LOOP

      sales_tbl(i).AMOUNT_SOLD := sales_tbl(i).AMOUNT_SOLD * 1.5;

    END LOOP;

    

    --<방법1> FETCH 된 1000건을 SQL 1회 수행으로 처리

    FORALL i IN sales_tbl.FIRST..sales_tbl.LAST

      INSERT INTO SALES2 VALUES (sales_tbl(i).PROD_ID,

                                 sales_tbl(i).CUST_ID,

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

                                 sales_tbl(i).TIME_ID,

                                 sales_tbl(i).CHANNEL_ID,

                                 sales_tbl(i).PROMO_ID,

                                 sales_tbl(i).QUANTITY_SOLD,

                                 sales_tbl(i).AMOUNT_SOLD

                                 );

 

-- <방법2> LOOP를 사용하는 방법; INSERT SQL 1000 번 수행 (속도는 방법1 보다 30배 이상 느림)

--    FOR i IN sales_tbl.FIRST..sales_tbl.LAST LOOP

--      INSERT INTO SALES2 VALUES (sales_tbl(i).PROD_ID,

--                                 sales_tbl(i).CUST_ID,

--                                 sales_tbl(i).TIME_ID,

--                                 sales_tbl(i).CHANNEL_ID,

--                                 sales_tbl(i).PROMO_ID,

--                                 sales_tbl(i).QUANTITY_SOLD,

--                                 sales_tbl(i).AMOUNT_SOLD

--                                 );

--

--    END LOOP;

 

 

    -- UPDATE / DELETE 도 가능

    FORALL i IN sales_tbl.FIRST..sales_tbl.LAST

      UPDATE SALES SET AMOUNT_SOLD = sales_tbl(i).AMOUNT_SOLD

      WHERE PROD_ID = sales_tbl(i).PROD_ID

        AND CUST_ID = sales_tbl(i).CUST_ID

        AND TIME_ID = sales_tbl(i).TIME_ID

        AND CHANNEL_ID = sales_tbl(i).CHANNEL_ID

        AND PROMO_ID = sales_tbl(i).PROMO_ID;

 

    EXIT WHEN sales_cur%NOTFOUND;

  

  END LOOP;

  

  CLOSE sales_cur;

  COMMIT;

  

EXCEPTION

    WHEN OTHERS THEN

        ROLLBACK;

        RAISE_APPLICATION_ERROR(-20001,'RAISE_APPLICATION_ERROR : ' ||SQLCODE||':'|| SUBSTR(SQLERRM,1,200));

END;

 

 

[출처] https://m.blog.naver.com/inhim/100154127152

 

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
825 [오라클, oracle] ORA-00926:missing VALUES keyword 오류 졸리운_곰 2020.11.07 343
824 [mongodb] Get substring in MongoDB aggregate 졸리운_곰 2020.11.07 86
823 [mongodb] mongodb에서 문자열 검색 쿼리 졸리운_곰 2020.11.07 53
822 [oracle] [오라클] SUBSTR, SUBSTRB 함수 사용방법 (문자열, 자르기, 바이트, Left) file 졸리운_곰 2020.11.07 165
821 [Oracle] ORA-00917: 누락된 콤마 졸리운_곰 2020.11.07 1019
820 MongoDB Java: Finding objects in Mongo using QueryBuilder $in operator returns nothing 졸리운_곰 2020.11.07 26
819 [oracle] 오라클 MOD 함수(나머지 구하기 함수, 초를 분으로 변경) 졸리운_곰 2020.11.07 30
818 MongoDB (RDB와 비교, 특징과 장단점, 메모리성능 이슈, 주요용어) file 졸리운_곰 2020.11.07 25
817 [mongoDB] java driver insertMany() application 졸리운_곰 2020.10.27 10
816 MongoDB 스키마 디자인을 위한 6가지 규칙 요약 졸리운_곰 2020.10.10 14
815 [몽고디비 mongodb] MongoDB Bulk Insert – MongoDB insertMany file 졸리운_곰 2020.10.09 15
814 [mongodb 몽고디비] How to insert multiple document into a MongoDB collection using Java? 졸리운_곰 2020.10.09 39
813 [몽고디비 mongodb] 몽고디비에서 벌크 오퍼려이션과 배열 삽입의 차이점은 what is the difference between bulk insert and array insert in Mongo db operations 졸리운_곰 2020.10.09 138
812 Mongodb Bulk operation 졸리운_곰 2020.10.09 51
811 MongoDB Bulk Write(대랑 쓰기) & Retryable Write(쓰기 재시도) file 졸리운_곰 2020.10.09 103
810 [oracle] 성능 향상을 위한 다중 로우 처리 졸리운_곰 2020.10.09 32
» BULK SQL 사용예 졸리운_곰 2020.10.09 33
808 Importing wikipedia dump to MySql 졸리운_곰 2020.10.04 41
807 How to work with MongoDB in .NET file 졸리운_곰 2020.09.30 46
806 실습 2 - GROUP 졸리운_곰 2020.09.30 20
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED