用BULK COLLECT 減小LOOP的開銷(1)
DECLARE
-- ALL_ROWS NUMBER(10);
TYPE LAST_NAME_TAB IS RECORD(
sorder_no VARCHAR2(30),
mem_id VARCHAR2(50),
createddt DatE,
usertype integer,
delegate_id VARCHAR2(50));
LAST_NAME_ARR LAST_NAME_TAB;
TYPE T_SORDER IS TABLE OF LAST_NAME_TAB;
VAR_EDM T_SORDER := T_SORDER();
CURSOR P_CUR IS(
SELECT DISTINCT decode(a.order_type,
'ReturnOrder',
a.ref_order_no,
sorder_no) sorder_no,
mem_id,
createddt,
b.usertype,
a.delegate_id
FROM user);
-- ALL_ROWS NUMBER(10);
TYPE LAST_NAME_TAB IS RECORD(
sorder_no VARCHAR2(30),
mem_id VARCHAR2(50),
createddt DatE,
usertype integer,
delegate_id VARCHAR2(50));
LAST_NAME_ARR LAST_NAME_TAB;
TYPE T_SORDER IS TABLE OF LAST_NAME_TAB;
VAR_EDM T_SORDER := T_SORDER();
CURSOR P_CUR IS(
SELECT DISTINCT decode(a.order_type,
'ReturnOrder',
a.ref_order_no,
sorder_no) sorder_no,
mem_id,
createddt,
b.usertype,
a.delegate_id
FROM user);
BEGIN
OPEN p_cur;
FETCH P_CUR BULK COLLECT
INTO VAR_EDM;
OPEN p_cur;
FETCH P_CUR BULK COLLECT
INTO VAR_EDM;
FOR I IN 1 .. VAR_EDM.COUNT() LOOP
/*INSERT \* +APPEND *\
INTO PTL_SYSTEM_MESSAGE
(USERID, CREATEDBY, MAILADDRESS, TEMPLATE_ID)
VALUES
(VAR_EDM(I).USERID, VAR_EDM(I).CREATEDBY, VAR_EDM(I).MAILADDRESS, VAR_EDM(I)
.TEMPLATE_ID);
COMMIT;*/
DBMS_OUTPUT.PUT_LINE(VAR_EDM(I).mem_id || '---' || VAR_EDM(I)
.CREATEDDT || '---' || VAR_EDM(I)
.usertype || '---' || VAR_EDM(I)
.delegate_id || '---' || VAR_EDM(I).SORDER_NO);
END LOOP;
END;
/*INSERT \* +APPEND *\
INTO PTL_SYSTEM_MESSAGE
(USERID, CREATEDBY, MAILADDRESS, TEMPLATE_ID)
VALUES
(VAR_EDM(I).USERID, VAR_EDM(I).CREATEDBY, VAR_EDM(I).MAILADDRESS, VAR_EDM(I)
.TEMPLATE_ID);
COMMIT;*/
DBMS_OUTPUT.PUT_LINE(VAR_EDM(I).mem_id || '---' || VAR_EDM(I)
.CREATEDDT || '---' || VAR_EDM(I)
.usertype || '---' || VAR_EDM(I)
.delegate_id || '---' || VAR_EDM(I).SORDER_NO);
END LOOP;
END;
-------------------------------------------------------------------------------------------------------------
透過bulk collect減少loop處理的開銷
採用bulk collect可以將查詢結果一次性地載入到collections中。
而不是透過cursor一條一條地處理。
可以在select into,fetch into,returning into語句使用bulk collect。
注意在使用bulk collect時,所有的into變數都必須是collections.
舉幾個簡單的例子:
--在select into語句中使用bulk collect
DECLARE
TYPE SalList IS TABLE OF emp.sal%TYPE;
sals SalList;
BEGIN
-- Limit the number of rows to 100.
SELECT sal BULK COLLECT INTO sals FROM emp
WHERE ROWNUM <= 100;
-- Retrieve 10% (approximately) of the rows in the table.
SELECT sal BULK COLLECT INTO sals FROM emp SAMPLE 10;
TYPE SalList IS TABLE OF emp.sal%TYPE;
sals SalList;
BEGIN
-- Limit the number of rows to 100.
SELECT sal BULK COLLECT INTO sals FROM emp
WHERE ROWNUM <= 100;
-- Retrieve 10% (approximately) of the rows in the table.
SELECT sal BULK COLLECT INTO sals FROM emp SAMPLE 10;
END;
/
/
--在fetch into中使用bulk collect
DECLARE
TYPE DeptRecTab IS TABLE OF dept%ROWTYPE;
dept_recs DeptRecTab;
CURSOR c1 IS
SELECT deptno, dname, loc FROM dept WHERE deptno > 10;
BEGIN
OPEN c1;
FETCH c1 BULK COLLECT INTO dept_recs;
END;
/
TYPE DeptRecTab IS TABLE OF dept%ROWTYPE;
dept_recs DeptRecTab;
CURSOR c1 IS
SELECT deptno, dname, loc FROM dept WHERE deptno > 10;
BEGIN
OPEN c1;
FETCH c1 BULK COLLECT INTO dept_recs;
END;
/
--在returning into中使用bulk collect
CREATE TABLE emp2 AS SELECT * FROM employees;
DECLARE
TYPE NumList IS TABLE OF employees.employee_id%TYPE;
enums NumList;
TYPE NameList IS TABLE OF employees.last_name%TYPE;
names NameList;
BEGIN
DELETE FROM emp2 WHERE department_id = 30
RETURNING employee_id, last_name BULK COLLECT INTO enums, names;
dbms_output.put_line('Deleted ' || SQL%ROWCOUNT || ' rows:');
FOR i IN enums.FIRST .. enums.LAST
LOOP
dbms_output.put_line('Employee #' || enums(i) || ': ' || names(i));
END LOOP;
END;
/
DROP TABLE emp2;
DECLARE
TYPE NumList IS TABLE OF employees.employee_id%TYPE;
enums NumList;
TYPE NameList IS TABLE OF employees.last_name%TYPE;
names NameList;
BEGIN
DELETE FROM emp2 WHERE department_id = 30
RETURNING employee_id, last_name BULK COLLECT INTO enums, names;
dbms_output.put_line('Deleted ' || SQL%ROWCOUNT || ' rows:');
FOR i IN enums.FIRST .. enums.LAST
LOOP
dbms_output.put_line('Employee #' || enums(i) || ': ' || names(i));
END LOOP;
END;
/
DROP TABLE emp2;
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22392018/viewspace-705263/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 用 Laravel Collect 收藏文章Laravel
- 7.53 COLLECT
- swiper.js loop 小坑JSOOP
- Go 語言中的 collect 使用Go
- vue i18n-collect工具開發Vue
- 娛美德公開Q1財報:銷售額環比減少18%
- 一個用於文章收藏的擴充套件包 Laravel-Collect套件Laravel
- bulk forall 的測試(轉)
- 減小APK大小APK
- Elasticsearch——mget及bulkElasticsearch
- sqlserver bulk insert報錯Cannot bulk load because the file could not be opened.SQLServer
- 提高開發銷量小技巧
- 一個更好用的.NET Core程式瘦身器,減小程式尺寸到1/3
- Bulk-Crap-Uninstaller:一個高效解除安裝,輕鬆管理你的應用程式的.Net開源工具開源工具
- 【elasticsearch】bulk api奇特的json格式的原因ElasticsearchAPIJSON
- 瀏覽器的event loop和node的event loop瀏覽器OOP
- 字串池化,減少1/3記憶體佔用字串記憶體
- 資料庫實現原理#1(Nested Loop Join)資料庫OOP
- BULK In-BIND與RECORD(轉)
- mongodb批量操作, bulk_write,MongoDB
- 最新kali之bulk_extractor
- IHS MARKIT:疫情或將導致全球汽車銷量減少1千萬輛
- Java8之Stream-強大的collect操作Java
- Good Loop:美國營銷人員應對Adland的氣候危機GoOOP
- 瀏覽器event loop和node的event loop講解瀏覽器OOP
- 看似好像沒用的小知識點 vol.1
- 一週50萬銷量,《Loop Hero》為何如此上頭?OOP
- 10個實用的UX設計作品推銷小竅門UX
- [譯]探索Kotlin中隱藏的效能開銷-Part 1Kotlin
- 開發適用於微信小程式的跨平臺圖表庫:part1微信小程式
- [譯] 讓 Apache Cassandra 尾部延遲減小 10 倍,已開源Apache
- node中的Event LoopOOP
- hey,你的Event LoopOOP
- 更相減損術的應用
- 微信小遊戲開發(1)遊戲開發
- 傢俱銷售小程式開發如何盈利
- 如何減小微信小程式程式碼包大小微信小程式
- 遊戲關卡中的型別運用:《LOOP》的無限可能遊戲型別OOP
- ThinkPHP開發的實用小程式原始碼PHP原始碼