国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > 綜合 > 正文

批量綁定(bulk binds):FOR循環(huán)與FORALL的性能比較

2024-07-21 02:39:51
字體:
供稿:網(wǎng)友
  通常在SQL語句中給PL/SQL變量賦值叫做綁定(Binding),一次綁定一個(gè)完整的集合稱為批量綁定(Bulk Binding)。
  
  批量綁定(Bulk binds)可以通過減少在PL/SQL和SQL引擎之間的上下文切換(context switches )提高了性能.
  
  批量綁定(Bulk binds)包括:
  
  (i) Input collections, use the FORALL statement,一般用來改善DML(INSERT、UPDATE和DELETE) 操作的性能
  
  (ii) Output collections, use BULK COLLECT clause,一般用來提高查詢(SELECT)的性能
  
  FORALL的語法如下:
  
  FORALL index IN lower_bound..upper_bound sql_statement;
  
  下面是一個(gè)簡(jiǎn)單測(cè)試,用以說明FORALL與FOR循環(huán)的性能差異。
  SQL> drop table blktest;
  
  Table dropped.
  
  Elapsed: 00:00:00.13
  SQL>
  SQL> CREATE TABLE blktest (num NUMBER(20), name varchar2(50));
  
  Table created.
  
  Elapsed: 00:00:00.08
  SQL>
  SQL> CREATE OR REPLACE PROCEDURE bulktest
   2 IS
   3   TYPE numtab IS TABLE OF NUMBER (20)
   4    INDEX BY BINARY_INTEGER;
   5
   6   TYPE nametab IS TABLE OF VARCHAR2 (50)
   7    INDEX BY BINARY_INTEGER;
   8
   9   pnums  numtab;
   10   pnames  nametab;
   11   t1    NUMBER;
   12   t2    NUMBER;
   13   t3    NUMBER;
   14 BEGIN
   15   FOR j IN 1 .. 1000000
   16   LOOP
   17    pnums (j)     := j;
   18    pnames (j)    := 'Seq No. ' TO_CHAR (j);
   19   END LOOP;
   20
   21   SELECT DBMS_UTILITY.get_time
   22    INTO t1
   23    FROM DUAL;
   24
   25   FOR i IN 1 .. 1000000
   26   LOOP
   27    INSERT INTO blktest
   28       VALUES (pnums (i), pnames (i));
   29   END LOOP;
   30
   31   SELECT DBMS_UTILITY.get_time
   32    INTO t2
   33    FROM DUAL;
   34
   35   FORALL i IN 1 .. 1000000
   36    INSERT INTO blktest
   37       VALUES (pnums (i), pnames (i));
   38
   39   SELECT DBMS_UTILITY.get_time
   40    INTO t3
   41    FROM DUAL;
   42
   43   DBMS_OUTPUT.put_line ('Execution Time (hsecs)');
   44   DBMS_OUTPUT.put_line ('---------------------');
   45   DBMS_OUTPUT.put_line ('FOR loop: ' TO_CHAR (t2 - t1));
   46   DBMS_OUTPUT.put_line ('FORALL:  ' TO_CHAR (t3 - t2));
   47 END;
   48 /
  
  Procedure created.
  
  Elapsed: 00:00:01.46
  SQL> exec bulktest;
  Execution Time (hsecs)
  ---------------------
  FOR loop: 30361
  FORALL:  4792
  
  PL/SQL procedure sUCcessfully completed.
  
  Elapsed: 00:06:32.92
  
  我們可以看到FORALL較FOR循環(huán)性能大大提高。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 天门市| 福鼎市| 南涧| 普兰店市| 衡阳市| 永善县| 肇源县| 仙游县| 凭祥市| 龙口市| 孙吴县| 岳池县| 肇庆市| 忻城县| 靖边县| 怀化市| 涪陵区| 孝昌县| 双流县| 宜川县| 正安县| 车致| 汉中市| 特克斯县| 长顺县| 满洲里市| 长春市| 莱芜市| 云南省| 望谟县| 湘阴县| 赣榆县| 西宁市| 滦南县| 巨鹿县| 哈巴河县| 星子县| 祁连县| 若羌县| 温州市| 沂源县|