성능 향상을 위한 다중 로우 처리

정적 SQL이든 동적 SQL이든 한 개 이상의 결과를 반환하는 SELECT문의 결과 집합을 받아 오기 위해 필요한 것은 세 가지인데, 바로 커서와 결과를 받아 오는 그릇 역할을 하는 커서나 레코드 변수, 그리고 LOOP나 FOR 같은 반복문이다. 즉 SQL문에 대한 커서를 연 뒤, 루프를 돌며 결과를 패치해 변수에 담고 루프가 끝나면 커서를 닫는다. 그런데 만약 쿼리 결과로 반환되는 로우 수가 많다면 루프를 돌면서 결과를 패치하는 식의 처리는 시간도 많이 걸리고 성능 면에서 좋지 않다. 일일이 한 로우씩 읽어 가며 결과를 받아올 것이 아니라 SQL의 장점인 집합적으로 처리하는 방법이 있다면 더 좋지 않을까? 바로 BULK COLLECT INTO 절을 사용해서 이를 구현할 수 있다. 먼저 정적 SQL을 이용한 예제를 살펴 보자.

입력

    -- BULK COLLECT INTO를 사용한 정적 SQL
    DECLARE
      -- 레코드 선언
      TYPE rec_physicist IS RECORD  (
        ids ch13_physicist.ids%TYPE,
        names ch13_physicist.names%TYPE,
        birth_dt ch13_physicist.birth_dt%TYPE );

      -- 레코드를 항목으로 하는 중첩 테이블 선언
      TYPE NT_physicist IS TABLE OF rec_physicist;

      -- 중첩 테이블 변수 선언
      vr_physicist NT_physicist;
    BEGIN
      BULK COLLECT INTO절(패치가 한 번에 이루어 진다)
      SELECT *
        BULK COLLECT INTO vr_physicist
        FROM ch13_physicist;
      -- 루프를 돌며 출력(이 루프는 값을 패치하는 것이 아니라 출력하기 위한 루프임)
      FOR i IN 1..vr_physicist.count
      LOOP
        DBMS_OUTPUT.PUT_LINE(vr_physicist(i).names);
      END LOOP;
    END;

결과

    Galileo Galilei
    Isaac Newton
    Max Plank
    Albert Einstein

쿼리를 수행한 결과 로우 수가 1개일 때는 SELECT INTO를, 2개 이상일 때는 커서를 사용해 결과를 변수에 담았는데, 위 예제에서는 SELECT … BULK COLLECT INTO 구문을 사용해 컬렉션 변수에 결과 집합을 담았다. 기존에 커서를 사용해 루프를 돌며 로우 하나씩 데이터를 받은 것에 비하면 코드도 훨씬 줄어 들었을 뿐만 아니라 성능 면에서도 우수하다. BULK COLLECT INTO 절은 동적 SQL에서도 사용할 수 있다. 정적 SQL에서는 SELECT 구문에 직접 들어갔지만, 동적 SQL에서는 EXECUTE IMMEDIATE 문에 포함된다.

입력

    DECLARE
      -- 레코드 선언
      TYPE rec_physicist IS RECORD  (
        ids ch13_physicist.ids%TYPE,
        names ch13_physicist.names%TYPE,
        birth_dt ch13_physicist.birth_dt%TYPE );
      -- 레코드를 항목으로 하는 중첩 테이블 선언
      TYPE NT_physicist IS TABLE OF rec_physicist;

      -- 중첩 테이블 변수 선언
      vr_physicist NT_physicist;

      vs_sql VARCHAR2(1000);
      vn_ids ch13_physicist.ids%TYPE := 1;
    BEGIN
      -- SELECT 구문
      vs_sql := 'SELECT * FROM ch13_physicist WHERE ids > :a' ;

      -- EXECUTE IMMEDIATE .. BULK COLLECT INTO 구문
      EXECUTE IMMEDIATE vs_sql BULK COLLECT INTO vr_physicist USING vn_ids;

      -- 루프를 돌며 출력
      FOR i IN 1..vr_physicist.count
      LOOP
        DBMS_OUTPUT.PUT_LINE(vr_physicist(i).names);
      END LOOP;

    END;

결과

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

    Isaac Newton
    Max Plank
    Albert Einstein

동적 SQL에서는 BULK COLLECT INTO 절이 EXECUTE IMMEDIATE 문의 쿼리 문자열과 USING 사이에 위치한다. 동적 SQL 역시 BULK COLLECT INTO 절을 사용하는 것이 커서 보다는 가독성과 성능 면에서 우수하므로, 결과 집합 건수가 많을 때는 이 방법을 사용하자.

 

[출처] https://thebook.io/006696/part03/ch13/02/03/

 

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
823 [mongodb] mongodb에서 문자열 검색 쿼리 졸리운_곰 2020.11.07 51
822 [oracle] [오라클] SUBSTR, SUBSTRB 함수 사용방법 (문자열, 자르기, 바이트, Left) file 졸리운_곰 2020.11.07 165
821 [Oracle] ORA-00917: 누락된 콤마 졸리운_곰 2020.11.07 1016
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 50
811 MongoDB Bulk Write(대랑 쓰기) & Retryable Write(쓰기 재시도) file 졸리운_곰 2020.10.09 103
» [oracle] 성능 향상을 위한 다중 로우 처리 졸리운_곰 2020.10.09 32
809 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
805 MongoDB : 기본 구조 file 졸리운_곰 2020.09.30 23
804 [tensorflow] 텐서플로로 음악 작곡 : Generate Music in TensorFlow 졸리운_곰 2020.09.27 57
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED