Oracle資料庫之FORALL與BULK COLLECT語句

來源:互聯網
上載者:User

Oracle資料庫之FORALL與BULK COLLECT語句

我們再來看一下PL/SQL塊的執行過程:當PL/SQL運行時引擎處理一塊代碼時,它使用PL/SQL引擎來執行過程化的代碼,而將SQL語句發送給SQL引擎來執行;SQL引擎執行完畢後,將結果再返回給PL/SQL引擎。這種在PL/SQL引擎和SQL引擎之間的互動,稱為上下文交換(context switch)。每發生一次交換,就會帶來一定的額外開銷。

 

  1. FORALL,用於增強PL/SQL引擎到SQL引擎的交換。
  2. BULK COLLECT,用於增強SQL引擎到PL/SQL引擎的交換。(前面我們已經介紹過了)

1. FORALL介紹

使用FORALL,可以將多個DML批量發送給SQL引擎來執行,最大限度地減少上下文互動所帶來的開銷。下面是 FORALL 的一個:

文法:

 

1 FORALL index_name IN 2     { lower_bound .. upper_bound3     | INDICES 

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.