欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle 12CR2查詢轉換教程之cursor-duration臨時表詳解

 更新時間:2018年11月01日 10:08:05   作者:jydba  
這篇文章主要給大家介紹了關于Oracle 12CR2查詢轉換教程之cursor-duration臨時表的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

在Oracle12C中為了物化查詢的中間結果,Oracle數據庫在查詢編譯時在內存中可能會隱式的創(chuàng)建一個cursor_duration臨時表。

下面話不多說了,來一起看看詳細的介紹吧

Cursor-Duration臨時表的作用

復雜查詢有時會處理相同查詢塊多次,這將會增加不必要的性能開鎖。為了避免這種問題,Oracle數據庫可以在游標生命周期內為查詢結果創(chuàng)建臨時表并存儲在內存中。對于有with子句查詢,星型轉換與分組集合操作的復雜操作,這種優(yōu)化增強了使用物化中間結果來優(yōu)化子查詢。在這種方式下,cursor-duration臨時表提高了性能并且優(yōu)化了I/O。

Cursor-Duration臨時表工作原理

cursor-definition臨時表定義內置在內存中。表定義與游標相關,并且只對執(zhí)行游標的會話可見。當使用cursor-duration臨時表時,數據庫將執(zhí)行以下操作:

1.選擇使用cursor-duration臨時表的執(zhí)行計劃

2.創(chuàng)建臨時表時使用唯一名

3.重寫查詢引用臨時表

4.加載數據到內存中直到沒有內存可用,在這種情次品下將在磁盤上創(chuàng)建臨時段

5.執(zhí)行查詢,從臨時表中返回數據

6.truncate表,釋放內存與任何磁盤上的臨時段

注意,cursor-duration臨時表的元數據只要cursor在內存中就會一直存在于內存中。元數據不會存儲在數據字典中這意味著通過數據字典視圖將不能查詢到,不能顯性地刪除元數據。上面的場景依賴于可用的內存。對于特定查詢,臨時表使用PGA內存。

cursor-duration臨時表的實現類似于排序。如果沒有可用內存,那么數據庫將把數據寫入臨時段。對于cursor-duration臨時表,主要差異如下:

.在查詢結束時數據庫釋放內存與臨時段而不是當row source不現活動時釋放。

.內存中的數據仍然存儲在內存中,不像排序數據可能在內存與臨時段之間移動。

當數據庫使用cursor-duration臨時表時,關鍵字cursor duration memory會出現在執(zhí)行計劃中。

cursor-duration臨時表使用場景

一個with查詢重復相同子查詢多次可能有時使用cursor-duration臨時表性能更高,下面的查詢使用一個with子句來創(chuàng)建三個子查詢塊:

SQL> set long 99999
SQL> set linesize 300
SQL> with
 2 q1 as (select department_id, sum(salary) sum_sal from hr.employees group by
 3 department_id),
 4 q2 as (select * from q1),
 5 q3 as (select department_id, sum_sal from q1)
 6 select * from q1
 7 union all
 8 select * from q2
 9 union all
 10 select * from q3;

DEPARTMENT_ID SUM_SAL
------------- ----------
   100  51608
   30  24900
     7000
   90  58000
   20  19000
   70  10000
   110  20308
   50  156400
   80  304500
   40  6500
   60  28800
   10  4400
   100  51608
   30  24900
     7000
   90  58000
   20  19000
   70  10000
   110  20308
   50  156400
   80  304500
   40  6500
   60  28800
   10  4400
   100  51608
   30  24900
     7000
   90  58000
   20  19000
   70  10000
   110  20308
   50  156400
   80  304500
   40  6500
   60  28800
   10  4400

36 rows selected.

下面是優(yōu)化轉換后的執(zhí)行計劃

SQL> select * from table(dbms_xplan.display_cursor(format=>'basic +rows +cost'));

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
EXPLAINED SQL STATEMENT:
------------------------
with q1 as (select department_id, sum(salary) sum_sal from hr.employees
group by department_id), q2 as (select * from q1), q3 as (select
department_id, sum_sal from q1) select * from q1 union all select *
from q2 union all select * from q3

Plan hash value: 4087957524

----------------------------------------------------------------------------------------------------
| Id | Operation        | Name      | Rows | Cost (%CPU)|

PLAN_TABLE_OUTPUT
----------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT       |       |  |  6 (100)|
| 1 | TEMP TABLE TRANSFORMATION    |       |  |   |
| 2 | LOAD AS SELECT (CURSOR DURATION MEMORY)| SYS_TEMP_0FD9E08D2_620789C |  |   |
| 3 | HASH GROUP BY       |       | 11 | 276 (2)|
| 4 |  TABLE ACCESS FULL     | EMPLOYEES     | 100K| 273 (1)|
| 5 | UNION-ALL        |       |  |   |
| 6 | VIEW         |       | 11 |  2 (0)|
| 7 |  TABLE ACCESS FULL     | SYS_TEMP_0FD9E08D2_620789C | 11 |  2 (0)|
| 8 | VIEW         |       | 11 |  2 (0)|
| 9 |  TABLE ACCESS FULL     | SYS_TEMP_0FD9E08D2_620789C | 11 |  2 (0)|
| 10 | VIEW         |       | 11 |  2 (0)|
| 11 |  TABLE ACCESS FULL     | SYS_TEMP_0FD9E08D2_620789C | 11 |  2 (0)|
----------------------------------------------------------------------------------------------------


26 rows selected.

在上面的執(zhí)行計劃中,在步驟1中的TEMP TABLE TRANSFORMATION指示數據庫使用cursor-duration臨時表來執(zhí)行查詢。在步驟2中的CURSOR DURATION MEMORY指示數據庫使用內存,如果有可用內存,將結果作為臨時表SYS_TEMP_0FD9E08D2_620789C來進行存儲。如果沒有可用內存,那么數據庫將臨時數據寫入磁盤。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • Oracle 存儲過程教程

    Oracle 存儲過程教程

    一個簡單的oracle分頁存儲過程的實現和調用。在看了眾多的分頁存儲過程以后發(fā)現都是針對sqlserver的,而沒有oracle的,因此想寫一個關于oracle的存儲過程,因為我用到的數據庫是oracle。
    2009-10-10
  • Oracle中的instr()函數應用及使用詳解

    Oracle中的instr()函數應用及使用詳解

    這篇文章主要介紹了Oracle中的instr()函數應用及使用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • oracle獲取當前時間,精確到毫秒并指定精確位數的實現方法

    oracle獲取當前時間,精確到毫秒并指定精確位數的實現方法

    下面小編就為大家?guī)硪黄猳racle獲取當前時間,精確到毫秒并指定精確位數的實現方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • oracle中distinct的用法詳解

    oracle中distinct的用法詳解

    distinct這個關鍵字來過濾掉多余的重復記錄只保留一條,但往往只用它來返回不重復記錄的條數,而不是用它來返回不重記錄的所有值。其原因是distinct只有用二重循環(huán)查詢來解決,而這樣對于一個數據量非常大的站來說,無疑是會直接影響到效率的。
    2015-09-09
  • oracle 函數判斷字符串是否包含圖片格式的實例代碼

    oracle 函數判斷字符串是否包含圖片格式的實例代碼

    本文通過實例代碼給大家介紹了oracle 函數判斷字符串是否包含圖片格式的相關資料,需要的朋友可以參考下
    2017-07-07
  • ORACLE常見錯誤代碼的分析與解決(三)

    ORACLE常見錯誤代碼的分析與解決(三)

    ORACLE常見錯誤代碼的分析與解決(三)...
    2007-03-03
  • Oracle 臨時表空間SQL語句的實現

    Oracle 臨時表空間SQL語句的實現

    臨時表空間用來管理數據庫排序操作以及用于存儲臨時表、中間排序結果等臨時對象,本文主要介紹了Oracle 臨時表空間SQL語句的實現,感興趣的可以了解一下
    2021-09-09
  • oracle11g 最終版本11.2.0.4安裝詳細過程介紹

    oracle11g 最終版本11.2.0.4安裝詳細過程介紹

    這篇文章主要介紹了oracle11g 最終版本11.2.0.4安裝詳細過程介紹,詳細的介紹了每個安裝步驟,有興趣的可以了解一下。
    2017-03-03
  • Oracle 數據庫連接查詢SQL語句

    Oracle 數據庫連接查詢SQL語句

    oracle 連接查詢分如下幾種方法,大家可以看看,整理了下oracle 內外鏈接。
    2009-08-08
  • Oracle 數據顯示 橫表轉縱表

    Oracle 數據顯示 橫表轉縱表

    橫表轉縱表亦可用與decode意義相似的case語句實現,原理同該語句,這里不再過多描述。
    2009-07-07

最新評論