日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Oracle Parallel Execution(并行执行) .

發布時間:2024/8/26 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Oracle Parallel Execution(并行执行) . 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

關于Oracle 的并行執行,Oracle 官方文檔有詳細的說明:

??????????????????????????????? Using Parallel Execution

http://download.oracle.com/docs/cd/E11882_01/server.112/e10837/parallel.htm#VLDBG010

This chapter covers tuning in a parallel execution environment and discusses the following topics:

·???????? Introduction to Parallel Execution

·???????? How Parallel Execution Works

·???????? Types of Parallelism

·???????? Initializing and Tuning Parameters for Parallel Execution

·???????? Tuning General Parameters for Parallel Execution

·???????? Monitoring Parallel Execution Performance

·???????? Miscellaneous Parallel Execution Tuning Tips

?

一.???? 并行(Parallel)和OLAP系統

并行的實現機制是: 首先,Oracle 會創建一個進程用于協調并行服務進程之間的信息傳遞,這個協調進程將需要操作的數據集(比如表的數據塊)分割成很多部分,稱為并行處理單元,然后并行協調進程給每個并行進程分配一個數據單元。比如有四個并行服務進程,他們就會同時處理各自分配的單元,當一個并行服務進程處理完畢后,協調進程就會給它們分配另外的單元,如此反復,直到表上的數據都處理完畢,最后協調進程負責將每個小的集合合并為一個大集合作為最終的執行結果,返回給用戶。

?

并行處理的機制實際上就是把一個要掃描的數據集分成很多小數據集,Oracle 會啟動幾個并行服務進程同時處理這些小數據集,最后將這些結果匯總,作為最終的處理結果返回給用戶。

?

這種數據并行處理方式在OLAP系統中非常有用,OLAP系統的表通常來說都是非常大,如果系統的CPU比較多,讓所有的CPU共同來處理這些數據,效果就會比串行執行要高的多。

?

然而對于OLTP系統,通常來講,并行并不合適,原因是OLTP系統上幾乎在所有的SQL操作中,數據訪問路勁基本上以索引訪問為主,并且返回結果集非常小,這樣的SQL 操作的處理速度一般非???#xff0c;不需要啟用并行。

?

?

二. 并行處理的機制

??????????????? 當Oracle 數據庫啟動的時候,實例會根據初始化參數:

??????????????????????????????? PARALLEL_MIN_SERVERS=n

??????????????? 的值來預先分配n個并行服務進程,當一條SQL 被CBO判斷為需要并行執行時發出SQL的會話進程變成并行協助進程,它按照并行執行度的值來分配進程服務器進程。

?

??????????????? 首先協調進程會使用ORACLE 啟動時根據參數: parallel_min_servers=n的值啟動相應的并行服務進程,如果啟動的并行服務器進程數不足以滿足并行度要求的并行服務進程數,則并行協調進程將額外啟動并行服務進程以提供更多的并行服務進程來滿足執行的需求。 然后星星協調進程將要處理的對象劃分成小數據片,分給并行服務進程處理;并行服務進程處理完畢后將結果發送給并行協調進程,然后由并行協調進程將處理結果匯總并發送給用戶。

?

??????????????? 剛才講述的是一個并行處理的基本流程。 實際上,在一個并行執行的過程中,還存在著并行服務進程之間的通信問題。

??????????????? 在一個并行服務進程需要做兩件事情的時候,它會再啟用一個進程來配和當前的進程完成一個工作,比如這樣的一條SQL語句:

??????????????? Select * from employees order by last_name;

???????????????

??????????????? 假設employees表中last_name 列上沒有索引,并且并行度為4,此時并行協調進程會分配4個并行服務進程對表employees進行全表掃描操作,因為需要對結果集進行排序,所以并行協調進程會額外啟用4個并行服務進程,用于處理4個進程傳送過來的數據,這新啟用的用戶處理傳遞過來數據的進程稱為父進程,用戶傳出數據(最初的4個并行服務進程)成為子進程,這樣整個并行處理過程就啟用了8個并行服務進程。 其中每個單獨的并行服務進程的行為叫作并行的內部操作,而并行服務進程之間的數據交流叫做并行的交互操作。

??????????????? 這也是有時我們發現并行服務進程數量是并行度的2倍,就是因為啟動了并行服務父進程操作的緣故。

?

?

三. 讀懂一個并行處理的執行計劃

?

CREATE TABLE emp2 AS SELECT * FROM employees;

ALTER TABLE emp2 PARALLEL 2;

?

EXPLAIN PLAN FOR

? SELECT SUM(salary) FROM emp2 GROUP BY department_id;

SELECT PLAN_TABLE_OUTPUT FROM TABLE(DBMS_XPLAN.DISPLAY());

?

--------------------------------------------------------------------------------------------------------

| Id? | Operation??????????????? | Name???? | Rows? | Bytes | Cost (%CPU) |??? TQ? |IN-OUT| PQ Distrib |

--------------------------------------------------------------------------------------------------------

|?? 0 | SELECT STATEMENT? ???????|????????? |?? 107 |? 2782 |???? 3 (34)? |??????? |????? |??????????? |

|?? 1 |? PX COORDINATOR????????? |????????? |?????? |?????? |???????????? |??????? |????? |??????????? |

|?? 2 |?? PX SEND QC (RANDOM)??? | :TQ10001 |?? 107 |? 2782 |???? 3 (34)? |? Q1,01 | P->S | QC (RAND)? |

|?? 3 |??? HASH GROUP BY???????? |????????? |?? 107 |? 2782 |???? 3 (34)? |? Q1,01 | PCWP |??????????? |

|?? 4 |???? PX RECEIVE?????????? |????????? |?? 107 |? 2782 |???? 3 (34)? |? Q1,01 | PCWP |??????????? |

|?? 5 |????? PX SEND HASH?????? ?| :TQ10000 |?? 107 |? 2782 |???? 3 (34)? |? Q1,00 | P->P | HASH?????? |

|?? 6 |?????? HASH GROUP BY????? |????????? |?? 107 |? 2782 |???? 3 (34)? |? Q1,00 | PCWP |??????????? |

|?? 7 |????? ??PX BLOCK ITERATOR |? ????????|?? 107 |? 2782 |???? 2 (0)?? |? Q1,00 | PCWP |??????????? |

|?? 8 |???????? TABLE ACCESS FULL| EMP2???? |?? 107 |? 2782 |???? 2 (0)?? |? Q1,00 | PCWP |??????????? |

--------------------------------------------------------------------------------------------------------

?

The table EMP2 is scanned in parallel by one set of slaves while the aggregation for the GROUP BY is done by the second set. The PX BLOCK ITERATOR row source represents the splitting up of the table EMP2 into pieces so as to divide the scan workload between the parallel scan slaves. The PX SEND and PX RECEIVE row sources represent the pipe that connects the two slave sets as rows flow up from the parallel scan, get repartitioned through the HASH table queue, and then read by and aggregated on the top slave set. The PX SEND QC row source represents the aggregated values being sent to the QC in random (RAND) order. The PX COORDINATOR row source represents the QC or Query Coordinator which controls and schedules the parallel plan appearing below it in the plan tree.

?

??????????????? 上面這段文字是從Oracle 聯機文檔上蕩下來的。

http://download.oracle.com/docs/cd/E11882_01/server.112/e10821/ex_plan.htm#PFGRF94687

?

通過執行計劃,我們來看一下它的執行步驟:

??????????????? (1)并行服務進程對EMP2表進行全表掃描。

??????????????? (2)并行服務進程以ITERATOR(迭代)方式訪問數據塊,也就是并行協調進程分給每個并行服務進程一個數據片,在這個數據片上,并行服務進程順序地訪問每個數據塊(Iterator),所有的并行服務進程將掃描的數據塊傳給另一組并行服務進程(父進程)用于做Hash Group操作。

??????????????? (3)并行服務父進程對子進程傳遞過來的數據做Hash Group操作。

??????????????? (4)并行服務進程(子進程)將處理完的數據發送出去。

??????????????? (5)并行服務進程(父進程)接收到處理過的數據。

??????????????? (6)合并處理過的數據,按照隨即的順序發給并行協調進程(QC:Query Conordinator)。

??????????????? (7)并行協調進程將處理結果發給用戶。

?

當使用了并行執行,SQL的執行計劃中就會多出一列:in-out。 該列幫助我們理解數據流的執行方法。 它的一些值的含義如下:

Parallel to Serial(P->S): 表示一個并行操作發送數據給一個串行操作,通常是并行incheng將數據發送給并行調度進程。

Parallel to Parallel(P->P):表示一個并行操作向另一個并行操作發送數據,疆場是兩個從屬進程之間的數據交流。

Parallel Combined with parent(PCWP): 同一個從屬進程執行的并行操作,同時父操作也是并行的。

Parallel Combined with Child(PCWC): 同一個從屬進程執行的并行操作,子操作也是并行的。

Serial to Parallel(S->P): 一個串行操作發送數據給并行操作,如果select 部分是串行操作,就會出現這個情況。

?

?

四.并行執行等待事件

??????????????? 在做并行執行方面的性能優化的時候,可能會遇到如下等待時間:

??????????????????????????????? PX Deq Credit: send blkd

??????????????? 這是一個有并行環境的數據庫中,從statspack 或者AWR中經??梢钥吹降牡却录?在Oracle 9i 里面, 這個等待時間被列入空閑等待。 關于等待時間參考:

??????????????? Oracle 常見的33個等待事件

??????????????? http://blog.csdn.net/tianlesoftware/archive/2010/08/12/5807800.aspx

?

一般來說空閑等待可以忽略它,但是實際上空閑等待也是需要關注的,因為一個空閑的等待,它反映的是另外的資源已經超負荷運行了。 基于這個原因,在Oracle 10g里已經把PX Deq Credit: send blkd等待時間不在視為空閑等待,而是列入了Others 等待事件范圍。

?

PX Deq Credit: send blkd 等待事件的意思是: 當并行服務進程向并行協調進程QC(也可能是上一層的并行服務進程)發送消息時,同一時間只有一個并行服務進程可以向上層進程發送消息,這時候如果有其他的并行服務進程也要發送消息,就只能等待了。 知道獲得一個發送消息的信用信息(Credit),這時候會觸發這個等待事件,這個等待事件的超時時間為2秒鐘。

?

??????????????? 如果我們啟動了太多的并行進程,實際上系統資源(CPU)或者QC 無法即時處理并行服務發送的數據,那么等待將不可避免。 對于這種情況,我們就需要降低并行處理的并行度。

?

??????????????? 當出現PX Deq Credit:send blkd等待的時間很長時,我們可以通過平均等待時間來判斷等待事件是不是下層的并行服務進程空閑造成的。該等待事件的超時時間是2秒,如果平均等待時間也差不多是2秒,就說明是下層的并行進程“無事所做”,處于空閑狀態。 如果和2秒的差距很大,就說明不是下層并行服務超時導致的空閑等待,而是并行服務之間的競爭導致的,因為這個平均等待事件非常短,說明并行服務進程在很短時間的等待之后就可以獲取資源來處理數據。

所以對于非下層的并行進程造成的等待,解決的方法就是降低每個并行執行的并行度,比如對象(表,索引)上預設的并行度或者查詢Hint 指定的并行度。

?

?

五. 并行執行的使用范圍

Oracle的并行技術在下面的場景中可以使用:

(1)?????? Parallel Query(并行查詢)

(2)?????? Parallel DDL(并行DDL操作,如建表,建索引等)

(3)?????? Parallel DML(并行DML操作,如insert,update,delete等)

?

5.1 并行查詢

??????????????? 并行查詢可以在查詢語句,子查詢語句中使用,但是不可以使用在一個遠程引用的對象上(如DBLINK)。

?

??????????????? 一個查詢能夠并行執行,需要滿足一下條件:

(1)?????? SQL語句中有Hint提示,比如Parallel 或者 Parallel_index.

(2)?????? SQL語句中引用的對象被設置了并行屬性。

(3)?????? 多表關聯中,至少有一個表執行全表掃描(Full table scan)或者跨分區的Index range SCAN。

?

如: select? /*+parallel(t 4) * from t;

?

5.2 并行DDL 操作

?

5.2.1 表操作的并行執行

??????????????? 以下表操作可以使用并行執行:

CREATE TABLE … AS SELECT

?????? ALTER TABLE … move partition

?????? Alter table … split partition

?????? Alter table … coalesce partition

?

DDL操作,我們可以通過trace 文件來查看它的執行過程。

?

示例:

?

查看當前的trace 文件:

/* Formatted on 2010/8/31 23:33:00 (QP5 v5.115.810.9015) */

SELECT????? u_dump.VALUE

???????? || '/'

???????? || db_name.VALUE

???????? || '_ora_'

???????? || v$process.spid

???????? || NVL2 (v$process.traceid, '_' || v$process.traceid, NULL)

???????? || '.trc'

??????????? "Trace File"

? FROM??????????? v$parameter u_dump

?????????????? CROSS JOIN

????????????????? v$parameter db_name

??????????? CROSS JOIN

?????????????? v$process

???????? JOIN

??????????? v$session

???????? ON v$process.addr = v$session.paddr

?WHERE?????? u_dump.name = 'user_dump_dest'

???????? AND db_name.name = 'db_name'

???????? AND v$session.audsid = SYS_CONTEXT ('userenv', 'sessionid');

?

Trace File

------------------------------------------------------------------------------

d:/app/administrator/diag/rdbms/orcl/orcl/trace/orcl_ora_5836.trc

d:/app/administrator/diag/rdbms/orcl/orcl/trace/orcl_ora_3048.trc

?

SQL> alter session set events '10046 trace name context forever,level 12';

會話已更改。

SQL> create table 懷寧 parallel 4 as select * from dba_objects;

表已創建。

SQL> alter session set events '10046 trace name context off' ;

會話已更改。

?

這里用到了ORACLE的event 時間。 10046事件是用來跟蹤SQL語句的。開啟事件后,相關的信息會寫道trace 文件中,這也是之前我們查看trace 文件名的原因。 關于event事件,參考我的blog:

??????????????? Oracle 跟蹤事件 set event

??????????????? http://blog.csdn.net/tianlesoftware/archive/2009/12/13/4977827.aspx

?

有了trace文件, 我們可以用tkprof 工具,來查看trace 文件的內容。 關于tkprof 工具介紹,參考blog:

??????????????? 使用 Tkprof 分析 ORACLE 跟蹤文件

??????????????? http://blog.csdn.net/tianlesoftware/archive/2010/05/29/5632003.aspx

?

?

進入trace 目錄,用tkprof命令生成txt 文件,然后查看txt 文件。

d:/app/Administrator/diag/rdbms/orcl/orcl/trace>tkprof orcl_ora_3048.trc 安慶.txt sys=no

TKPROF: Release 11.2.0.1.0 - Development on 星期二 8月 31 23:45:25 2010

Copyright (c) 1982, 2009, Oracle and/or its affiliates.? All rights reserved.

d:/app/Administrator/diag/rdbms/orcl/orcl/trace>

?

?

5.2.2 創建索引的并行執行

??????????????? 創建索引時使用并行方式在系統資源充足的時候會使性能得到很大的提高,特別是在OLAP系統上對一些很大的表創建索引時更是如此。 以下的創建和更改索引的操作都可以使用并行:

??????????????? Create index

??????????????? Alter index … rebuild

??????????????? Alter index … rebuild partition

??????????????? Alter index … split partition

?

一個簡單的語法:create index t_ind on t(id) parallel 4;

?

監控這個過程和5.2.1 中表一樣,需要通過10046事件。 這里就不多說了。

?

有關減少創建時間方法,參考blog:

??????????????? 如何加快建 index 索引 的時間

??????????????? http://blog.csdn.net/tianlesoftware/archive/2010/07/11/5664019.aspx

?

?

總結:

使用并行方式,不論是創建表,修改表,創建索引,重建索引,他們的機制都是一樣的,那就是Oracle 給每個并行服務進程分配一塊空間,每個進程在自己的空間里處理數據,最后將處理完畢的數據匯總,完成SQL的操作。

?

?

5.3 并行DML 操作

??????????????? Oracle 可以對DML操作使用并行執行,但是有很多限制。 如果我們要讓DML 操作使用并行執行,必須顯示地在會話里執行如下命令:

??????????????? SQL> alter session enable parallel dml;

會話已更改。

?

??????????????? 只有執行了這個操作,Oracle 才會對之后符合并行條件的DML操作并行執行,如果沒有這個設定,即使SQL中指定了并行執行,Oracle也會忽略它。

?

5.3.1 delete,update和merge 操作

??????????????? Oracle 對Delete,update,merge的操作限制在,只有操作的對象是分區表示,Oracle 才會啟動并行操作。原因在于,對于分區表,Oracle 會對每個分區啟用一個并行服務進程同時進行數據處理,這對于非分區表來說是沒有意義的。

?

5.3.2 Insert 的并行操作

??????????????? 實際上只有對于insert into … select … 這樣的SQL語句啟用并行才有意義。 對于insert into .. values… 并行沒有意義,因為這條語句本身就是一個單條記錄的操作。

?

??????????????? Insert 并行常用的語法是:

??????????????????????????????? Insert /*+parallel(t 2) */ into t select /*+parallel(t1 2) */ * from t1;

?

??????????????? 這條SQL 語句中,可以讓兩個操作insert 和select 分別使用并行,這兩個并行是相互獨立,互補干涉的,也可以單獨使用其中的一個并行。

?

?

六. 并行執行的設定

?

6.1 并行相關的初始話參數

?

6.1.1 parallel_min_servers=n

??????????????? 在初始化參數中設置了這個值,Oracle 在啟動的時候就會預先啟動N個并行服務進程,當SQL執行并行操作時,并行協調進程首先根據并行度的值,在當前已經啟動的并行服務中條用n個并行服務進程,當并行度大于n時,Oracle將啟動額外的并行服務進程以滿足并行度要求的并行服務進程數量。

?

6.1.2 parallel_max_servers=n

??????????????? 如果并行度的值大于parallel_min_servers或者當前可用的并行服務進程不能滿足SQL的并行執行要求,Oracle將額外創建新的并行服務進程,當前實例總共啟動的并行服務進程不能超過這個參數的設定值。

?

6.1.3 parallel_adaptive_multi_user=true|false

??????????????? Oracle 10g R2下,并行執行默認是啟用的。 這個參數的默認值為true,它讓Oracle根據SQL執行時系統的負載情況,動態地調整SQL的并行度,以取得最好的SQL??? 執行性能。

?

6.1.4 parallel_min_percent

??????????????? 這個參數指定并行執行時,申請并行服務進程的最小值,它是一個百分比,比如我們設定這個值為50. 當一個SQL需要申請20個并行進程時,如果當前并行服務進程不足,按照這個參數的要求,這個SQL比如申請到20*50%=10個并行服務進程,如果不能夠申請到這個數量的并行服務,SQL 將報出一個ORA-12827的錯誤。

??????????????? 當這個值設為Null時,表示所有的SQL在做并行執行時,至少要獲得兩個并行服務進程。

?

?

6.2 并行度的設定

??????????????? 并行度可以通過以下三種方式來設定:

(1)使用Hint 指定并行度。

(2)使用alter session force parallel 設定并行度。

(3)使用SQL中引用的表或者索引上設定的并行度,原則上Oracle 使用這些對象中并行度最高的那個值作為當前執行的并行度。

?

?

示例:

??????????????? SQL>Select /*+parallel(t 4) */ count(*) from t;

??????????????? SQL>Alter table t parallel 4;

??????????????? SQL>Alter session force parallel query parallel 4;

?

Oracle 默認并行度計算方式:

(1)Oracle 根據CPU的個數,RAC實例的個數以及參數parallel_threads_per_cpu的值,計算出一個并行度。

(2)對于并行訪問分區操作,取需要訪問的分區數為并行度。

?

并行度的優先級別從高到低:

??????????????? Hint->alter session force parallel->表,索引上的設定-> 系統參數

?

?

實際上,并行只有才系統資源比較充足的情況下,才會取得很好的性能,如果系統負擔很重,不恰當的設置并行,反而會使性能大幅下降。

?

?

七. 直接加載

??????????????? 在執行數據插入或者數據加載的時候,可以通過append hint的方式進行數據的直接加載。

?

在insert 的SQL中使用APPEND,如:

??????????????????????????????? Insert /*+append */ into t select * from t1;

???????????????

還可以在SQL*LOADER里面使用直接加載:

?????? Sqlldr userid=user/pwd control=load.ctl direct=true

?

Oracle 執行直接加載時,數據直接追加到數據段的最后,不需要花費時間在段中需找空間,數據不經過data buffer直接寫到數據文件中,效率要比傳統的加載方式高。

?

示例:

SQL> create table t as select * from user_tables;

表已創建。

SQL> select segment_name,extent_id,bytes from user_extents where segment_name='T';

SEGMENT_NA? EXTENT_ID????? BYTES

---------- ---------- ----------

T?????????????????? 0????? 65536

T?????????????????? 1????? 65536

T?????????????????? 2????? 65536

T?????????????????? 3????? 65536

T??????????? ???????4????? 65536

?

這里我們創建了一張表,分配了5個extents。

?

SQL> delete from t;

已刪除979行。

SQL> select segment_name,extent_id,bytes from user_extents where segment_name='T';

SEGMENT_NA? EXTENT_ID????? BYTES

---------- ---------- ----------

T?????????????????? 0????? 65536

T?????????????????? 1????? 65536

T?????????????????? 2????? 65536

T?????????????????? 3????? 65536

T?????????????????? 4????? 65536

?

這里刪除了表里的數據,但是查詢,依然占據5個extents。因為delete不會收縮表空間,不能降低高水位。

?

SQL> insert into t select * from user_tables;

已創建980行。

SQL> commit;

提交完成。

?

SQL> select segment_name,extent_id,bytes from user_extents where segment_name='T';

SEGMENT_NA? EXTENT_ID????? BYTES

---------- ---------- ----------

T?????????????????? 0????? 65536

T?????????????????? 1????? 65536

T?????????????????? 2????? 65536

T?????????????????? 3????? 65536

T?????????????????? 4????? 65536

?

用傳統方式插入,數據被分配到已有的空閑空間里。

?

?

SQL> delete from t;

已刪除980行。

SQL> commit;

提交完成。

SQL> select segment_name,extent_id,bytes from user_extents where segment_name='T';

SEGMENT_NA? EXTENT_ID????? BYTES

---------- ---------- ----------

T?????????????????? 0????? 65536

T?????????????????? 1????? 65536

T?????????????????? 2????? 65536

T?????????????????? 3????? 65536

T?????????????????? 4????? 65536

?

刪除數據,用append直接插入看一下。

?

SQL> insert /*+append */ into t select * from user_tables;

已創建980行。

SQL> commit;

提交完成。

SQL> select segment_name,extent_id,bytes from user_extents where segment_name='T';

SEGMENT_NA? EXTENT_ID????? BYTES

---------- ---------- ----------

T?????????????????? 0????? 65536

T?????????????????? 1????? 65536

T?????????????????? 2????? 65536

T?????????????????? 3????? 65536

T?????? ????????????4????? 65536

T?????????????????? 5????? 65536

T?????????????????? 6????? 65536

T?????????????????? 7????? 65536

T?????????????????? 8????? 65536

T?????????????????? 9????? 65536

已選擇10行。

?

從結果可以看出,直接加載方式時,雖然表中有很多空的數據塊,Oracle 仍然會額外的分配4個extent用于直接加載數據。

??????????????? 直接加載的數據放在表的高水位(High water Mark:hwm)以上,當直接加載完成后,Oracle 將表的高水位線移到新加入的數據之后,這樣新的數據就可以被用戶使用了。

?

Oracle 高水位(HWM)

http://blog.csdn.net/tianlesoftware/archive/2009/10/22/4707900.aspx

?

?

7.1 直接加載和REDO

??????????????? 直接加載在logging模式下,與傳統加載方式產生的redo 日志差別不大,因為當一個表有logging屬性時,即使使用直接加載,所有改變的數據依然要產生redo,實際上是所有修改的數據塊全部記錄redo,以便于以后的恢復,這時候直接加載并沒有太大的優勢。

?

??????????????? 直接加載最常見的是和nologging一起使用,這時候可以有效地減少redo 的生成量。 注意的是,在這種情況下,直接加載的數據塊是不產生redo的,只有一些其他改變的數據產生一些redo,比如表空間分配需要修改字典表或者修改段頭數據塊,這些修改會產生少量的redo。

?

??????????????? 實際上,對于nologging 方式的直接加載,undo 的數據量也產生的很少,因為直接加載的數據并不會在回滾段中記錄,這些記錄位于高水位之上,在事務提交之前,對于其他用戶來說是不可見的,所以不需要產生undo,事務提交時,Oracle 將表的高水位線移到新的數據之后,如果事務回滾,只需要保持高水位線不動即可,就好像什么都沒有發生一樣。

?

??????????????? 注意,由于在nologging模式下,redo 不記錄數據修改的信息,所以直接加載完后,需要立即進行相關的備份操作,因為這些數據沒有記錄在歸檔日志中,一旦數據損壞,只能用備份來恢復,而不能使用歸檔恢復。

?

Logging模式下示例:

SQL> set autot trace stat;

SQL> insert /*+append */ into t select * from user_tables;

已創建980行。

統計信息

----------------------------------------------------------

??????? 132? recursive calls

???????? 87? db block gets

?????? 8967? consistent gets

????????? 0? physical reads

???? 286572? redo size

??????? 911? bytes sent via SQL*Net to client

?????? 1017? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 2? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

SQL> rollback;

回退已完成。

SQL> insert into t select * from user_tables;

已創建980行。

統計信息

----------------------------------------------------------

????????? 0? recursive calls

??????? 144? db block gets

?????? 9027? consistent gets

????????? 0? physical reads

???? 267448? redo size

??????? 927? bytes sent via SQL*Net to client

?????? 1004? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 2? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

?

Nologging模式下示例:

SQL> alter table t nologging;

表已更改。

SQL> insert into t select * from user_tables;

已創建980行。

統計信息

----------------------------------------------------------

??????? 239? recursive calls

??????? 132? db block gets

?????? 9061? consistent gets

????????? 0? physical reads

???? 262896? redo size

??????? 927? bytes sent via SQL*Net to client

?????? 1004? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 7? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

SQL> rollback;

回退已完成。

SQL> insert /*+append */ into t select * from user_tables;

已創建980行。

統計信息

----------------------------------------------------------

????????? 8? recursive calls

???????? 40? db block gets

?????? 8938? consistent gets

????????? 0? physical reads

??????? 340? redo size? -- redo 減少很多

??????? 911? bytes sent via SQL*Net to client

?????? 1017? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 2? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

?

這部分內容也可參考Blog:

??????????????? Oracle DML NOLOGGING

http://blog.csdn.net/tianlesoftware/archive/2010/07/11/5701596.aspx

?

?

7.2 直接加載和索引

??????????????? 如果直接加載的表上有索引,Oracle不會像加載數據的方式那樣來處理索引的數據,但是它同樣需要維護一個索引,這個成本很高,同時會生成很多的redo。

??????????????? 所以當使用直接加載時,通常是針對一些數據量非常大的表。如果這些表存在索引,將會帶來很大的性能影響,這時可以考慮先將索引disable或者drop掉,等加載數據后,之后在重新建立索引。

?

nologging示例:

?

SQL> insert /*+append */ into t select * from user_tables;

已創建980行。

?

統計信息

----------------------------------------------------------

????????? 0? recursive calls

???????? 40? db block gets

?????? 8936? consistent gets

????????? 0? physical reads

??????? 384? redo size

??????? 911? bytes sent via SQL*Net to client

?????? 1017? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 2? sorts (memory)

????????? 0? sorts (disk)

?????? ?980? rows processed

?

SQL> rollback;

回退已完成。

SQL> create index t_ind on t(table_name);

索引已創建。

SQL> insert /*+append */ into t select * from user_tables;

已創建980行。

?

統計信息

----------------------------------------------------------

???????? 40? recursive calls

??????? 170? db block gets

?????? 8955? consistent gets

????????? 4? physical reads

???? 149424? redo size

??????? 911? bytes sent via SQL*Net to client

?????? 1017? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 3? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

SQL> rollback;

回退已完成。

SQL> insert? into t select * from user_tables;

已創建980行。

?

統計信息

----------------------------------------------------------

????????? 8? recursive calls

??????? 828? db block gets

?????? 9037? consistent gets

????????? 0? physical reads

???? 382832? redo size

??????? 927? bytes sent via SQL*Net to client

?????? 1005? bytes received via SQL*Net from client

????????? 4? SQL*Net roundtrips to/from client

????????? 2? sorts (memory)

????????? 0? sorts (disk)

??????? 980? rows processed

SQL> rollback;

回退已完成。

?

?

7.3 直接加載和并行

??????????????? 直接加載可以和并行執行一同使用,這樣可以并行地向表中插入數據。 如:

???????????????

SQL>alter session enable parallel dml; ?-- 這里必須顯示的申明

SQL>insert /*+append parallel(t,2) */ into t select * from t1;

SQL>insert /*+append */ into t select * from t1;

?

注:在對insert 使用并行時,Oracle自動使用直接加載的方式進行數據加載,所以在這種情況下append是可以省略的。

?

??????????????? 當使用并行加載時,Oracle 會按照并行度啟動相應數量的并行服務進程,像串行執行的直接加載的方式一樣,每個并行服務進程都單獨分配額外的空間用于加載數據,實際上Oracle 為每個并行服務進程分配了一個臨時段,每個并行服務進程將數據首先加載到各自的臨時段上,當所有的并行進程執行完畢后,將各自的數據塊合并到一起,放到高水位之后,如果事務提交,則將高水位移到新加載的數據之后。

?

?

7.4 直接加載和SQL*LOADER

??????????????? 在SQL*LOADER中也可以使用直接加載,它比傳統方式效率更高,因為它繞開了SQL的解析和數據緩沖區,直接將數據加載到數據文件,這對OLAP或者數據倉庫系統非常有用。

?

指定加載:

??????????????? Sqlldr userid=user/pwd control=control.ctl direct=true

?

指定并行和加載:

??????????????? Sqlldr userid=user/pwd control=control.ctl direct=true parallel=true

?

?

SQL*LOADER直接加載對索引的影響:

(1)索引為非約束性,直接加載可以在加載完畢后維護索引的完整性。

(2)索引為約束性索引,比如主鍵,直接加載仍然會將數據加載入庫,但是會將索引置為unusable.

?

?

如果使用SQL*LOADER的并行直接加載選項,并且表上有索引,將導致加載失敗,這是我們可以在sqlloader中指定skip_index_maintenance=true, 來允許加載完成,但是索引狀態會變成unusable,需要手工rebuild.

?

關于SQL*LOADER的更多內容,參考blog:

??????????????? Oracle SQL Loader

??????????????? http://blog.csdn.net/tianlesoftware/archive/2009/10/16/4674063.aspx

?

總結

以上是生活随笔為你收集整理的Oracle Parallel Execution(并行执行) .的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

日韩精品一区二区免费 | 91桃色在线观看视频 | 亚洲精品午夜国产va久久成人 | 日韩电影在线观看中文字幕 | 一本一道久久a久久精品 | 久草视频中文在线 | 欧美成人h版电影 | 国产精品 中文字幕 亚洲 欧美 | 日韩在线观看视频一区二区三区 | 婷婷av网 | 视频一区二区国产 | 麻豆 videos | 97视频免费在线观看 | 亚洲区另类春色综合小说校园片 | 亚洲婷久久 | 国精产品999国精产品岳 | 久久9999久久| 亚洲视频精品在线 | 久久久久久久久久影视 | 色香天天 | 久久黄色小说视频 | 中文字幕九九 | 日韩手机视频 | 99精品福利视频 | 正在播放一区二区 | 亚洲精品资源在线 | 看国产黄色片 | 三级av在线播放 | 亚洲五月花 | 亚洲91精品在线观看 | www激情网 | av免费成人| av电影免费在线播放 | 四虎国产精品永久在线国在线 | 欧美性黑人 | 国产精品女同一区二区三区久久夜 | 日日干影院 | 国产人成免费视频 | 久久综合久久综合这里只有精品 | 亚洲精品在线播放视频 | 香蕉手机在线 | 欧美美女一级片 | 久久免费视频1 | 在线观看国产成人av片 | 91精品国产91久久久久福利 | 激情小说 五月 | 波多野结衣精品视频 | 亚洲午夜大片 | 成片视频免费观看 | 国产色影院 | 992tv在线观看网站 | 国产精品欧美在线 | 1024手机在线看 | 午夜精品久久久久久久久久久 | 日韩午夜一级片 | 日韩精品一区二区三区免费观看视频 | 一区二区视频电影在线观看 | 欧美日韩精品在线播放 | 久久久久99精品成人片三人毛片 | 丁香花在线观看免费完整版视频 | 久一久久 | 黄色日本免费 | 亚洲精品国产精品国自产观看 | 国产精品亚洲片夜色在线 | 日日日干 | 免费高清影视 | 成人亚洲网 | 一级黄色片在线免费看 | 久久免费成人网 | 揉bbb玩bbb少妇bbb | 一区二区三区av在线 | 久久久久久毛片 | 日本乱码在线 | 亚洲最新av在线网站 | 亚洲一区二区高潮无套美女 | www.玖玖玖 | 午夜久久久久久久久久久 | 91精品一区二区三区蜜臀 | 黄a网| 在线视频观看你懂的 | 欧美一级片播放 | 91精品视频免费在线观看 | 欧美国产日韩在线视频 | 亚洲精品中文字幕在线观看 | 国产看片 色 | 成人av一区二区兰花在线播放 | 成年人网站免费观看 | 精品久久久久久综合 | 久久久高清免费视频 | 99综合电影在线视频 | 国产视频在线一区二区 | 欧美性色xo影院 | 亚洲精品黄色 | 中国一级片在线播放 | 国产精品亚洲视频 | 久久视频中文字幕 | 久久超| 国产aa精品| 久久高清国产 | 欧美在线观看视频一区二区 | 99视频在线免费观看 | 中文字幕在线免费观看 | 欧美精品久久久久久久久久丰满 | 99久热在线精品视频成人一区 | 日韩午夜在线 | 日韩大片在线观看 | 麻豆一精品传二传媒短视频 | 国产精品一区二区在线播放 | 中文字幕免费久久 | 亚洲黄色在线免费观看 | 亚洲在线高清 | 亚洲精品视频在线免费 | 亚洲精品免费看 | 国产精品va在线观看入 | 在线观看国产麻豆 | 久久成人久久 | 97超级碰碰碰碰久久久久 | 天天操天天干天天玩 | 国产精品久久在线 | 伊人视频 | 色噜噜在线观看视频 | 爱色av.com | 成年人免费在线播放 | 精品在线观 | 成人动图| 成人免费看电影 | 精品久久久久久久久久久久 | av电影中文| 美女网色| 国产精品久久久久一区二区三区共 | 亚洲电影自拍 | 国产精品美女www爽爽爽视频 | 在线视频区 | 91亚洲精品久久久中文字幕 | 狠狠干狠狠插 | 五月综合在线观看 | 成人在线视频免费 | 在线看片中文字幕 | 国产精品高潮呻吟久久av无 | 日本公妇在线观看 | 日本久久91 | 99久久精品日本一区二区免费 | 色综合久久久久综合99 | 欧美尹人| 精品成人a区在线观看 | 国产成人精品一区二区三区福利 | 免费黄色一区 | 国产成人在线播放 | 亚洲综合欧美精品电影 | 毛片在线播放网址 | 亚洲免费a | 午夜精品一区二区三区在线播放 | 国产一级二级av | 久久国内精品99久久6app | 91麻豆精品国产91久久久使用方法 | 国产亚洲视频在线观看 | 日韩两性视频 | 国产黄色特级片 | 日本视频高清 | 黄色三级网站 | 在线国产一区二区 | 三级av免费 | 色吊丝在线永久观看最新版本 | 在线高清av| 亚洲在线免费视频 | www日韩视频 | 久久久五月婷婷 | 久久精品网站免费观看 | 日韩精品一区二区三区电影 | 亚洲精品影视在线观看 | 国内精品久久久久久 | 9免费视频 | 成年人在线免费看 | 五月婷社区 | 亚洲动漫在线观看 | 欧美a级一区二区 | 丁香婷婷射 | 欧美精品久久久久性色 | 激情婷婷| 国产又黄又爽又猛视频日本 | 中文字幕在线观看一区二区 | 欧美最猛性xxxxx(亚洲精品) | 久久99久久99精品免费看小说 | 欧美精品久久久久 | 久草视频国产 | 色婷婷av一区 | 日韩一区在线播放 | 亚洲国产中文在线 | av在线电影网站 | 国产成人精品一区二区三区福利 | 成人午夜影院在线观看 | 欧美激情综合五月色丁香小说 | 亚洲视频精品 | 99久久久久国产精品免费 | 精品国产一区二 | 欧美三级在线播放 | 一区二区视频播放 | 天天玩天天干 | 欧美一区二区在线看 | 天天插天天爽 | 中文字幕韩在线第一页 | 中文字幕视频免费观看 | 黄色毛片电影 | av在线免费在线 | 69av免费视频| 日韩av成人在线观看 | 亚洲另类视频在线 | 99精品视频在线播放观看 | 韩国av免费在线 | 日韩黄色在线观看 | 国产成人333kkk | 日韩免费电影 | 成人中文字幕av | 欧美 日韩 性 | 久久综合加勒比 | av在观看 | 六月丁香婷婷久久 | 丰满少妇久久久 | 99精品免费在线 | 国产免费二区 | 亚洲人视频在线 | 久草在线免费新视频 | 92精品国产成人观看免费 | 色综合久久88色综合天天6 | 一区二区三区久久精品 | 黄色一级免费 | 亚洲精品av在线 | 亚洲综合网 | 午夜av色| 国产丝袜| 99久久久国产精品免费99 | 国产日韩中文在线 | 91最新中文字幕 | 成人久久精品 | 亚洲日韩中文字幕在线播放 | 国产福利在线免费 | 91免费在线看片 | 成人a免费视频 | 久久免费在线观看视频 | 国产免费xvideos视频入口 | 一区二区视频在线播放 | 6080yy精品一区二区三区 | 色播五月激情综合网 | 亚洲涩涩涩涩涩涩 | 欧美日韩三级在线观看 | 欧美久久精品 | 免费视频久久久久久久 | 日韩 国产 | 天天玩天天干 | 亚洲黄色免费观看 | 亚洲天堂网在线视频 | 欧美一二在线 | 在线色资源 | 伊人婷婷在线 | 69国产精品视频免费观看 | 免费高清无人区完整版 | 日日躁天天躁 | www久草 | 一级黄色电影网站 | 97在线观看免费视频 | 在线观看视频你懂得 | 999热线在线观看 | 中文字幕色站 | 久久精品三 | 91av在线电影 | 黄色免费观看视频 | 国产高清无线码2021 | 久草精品在线观看 | 日韩极品在线 | 免费福利小视频 | 久久字幕精品一区 | 日韩精品久久久久久中文字幕8 | 国产欧美综合在线观看 | 国内精品久久久久久久久久久 | 99视频久 | 99精品在线直播 | 国产一级电影在线 | 69精品 | 国产精品18毛片一区二区 | 亚洲精品小视频在线观看 | 久久国产一二区 | 久久久高清 | 婷婷五月情 | 久久精品免费观看 | 在线观看视频在线 | 一区二区三区av在线 | 日本不卡一区二区 | 国产在线观看地址 | 中文字幕av全部资源www中文字幕在线观看 | 日韩羞羞| 一区二区三区在线观看中文字幕 | 亚洲精品99久久久久中文字幕 | 国产视频一区精品 | 成人动漫视频在线 | 中文字幕日本电影 | 亚洲欧洲一区二区在线观看 | 国产小视频精品 | 婷婷久久一区 | 国产精品大片在线观看 | 国产最新精品视频 | 色国产精品 | 久久久久久国产精品 | 中文字幕区 | 色狠狠综合天天综合综合 | 狠狠躁日日躁狂躁夜夜躁 | 欧美精品久久久久久久久久丰满 | 天天综合日日夜夜 | 国产清纯在线 | 日韩免费在线一区 | 最新久久久 | 欧美孕妇视频 | 97视频精品| 欧美疯狂性受xxxxx另类 | 成人av视屏 | 久久久99久久 | 一级黄视频 | 五月婷婷综合激情网 | 超碰伊人网| 亚洲经典在线 | 成人av影视在线 | 天天干天天操人体 | 波多野结衣在线中文字幕 | 在线免费观看黄色小说 | 日本黄区免费视频观看 | 亚洲专区欧美 | 又黄又爽的视频在线观看网站 | 伊人久久国产 | 精品国产伦一区二区三区 | 日韩av伦理片 | 在线免费观看黄色av | 久久久国产精品免费 | www.69xx | 久久视频在线免费观看 | 国产视频综合在线 | 丁香婷婷综合激情五月色 | 天天夜夜亚洲 | 三级黄色a | 1000部18岁以下禁看视频 | 97成人资源| 日日摸日日碰 | 日韩啪啪小视频 | av片免费播放 | 久久黄色片 | 国产91在线免费视频 | 久久亚洲人 | 色综合天天色 | 久久综合爱 | av丁香花 | 欧美成人黄色 | 91精品1区 | 蜜臀av性久久久久蜜臀av | 狠狠躁日日躁狂躁夜夜躁 | 亚洲精品在线观看不卡 | 久久精品精品 | 国产精品资源在线观看 | av再线观看 | 精品天堂av | 日韩一区在线播放 | 成人91免费视频 | av在线8| 伊人国产女| 国产精品一区在线播放 | 久久躁日日躁aaaaxxxx | 日韩精品在线播放 | 国产亚洲久一区二区 | 国产精品国内免费一区二区三区 | 91网址在线看| 中文字幕av全部资源www中文字幕在线观看 | 看国产黄色片 | 亚洲黄色av| 日韩理论在线观看 | 亚洲久草在线视频 | 中文字幕在线视频国产 | 毛片网免费 | 你操综合 | 麻豆av电影| 三三级黄色片之日韩 | 97超碰人人看 | www.午夜| 国产免费成人av | 9色在线视频 | 亚洲欧美少妇 | 精品国产成人av在线免 | 亚洲视频国产 | 91色九色 | 国产女人18毛片水真多18精品 | 日韩中文字幕电影 | 91黄色小网站 | 精品视频中文字幕 | 97电影手机 | 欧日韩在线 | 成人a在线观看高清电影 | 波多野结衣久久资源 | 久久不卡免费视频 | 最近久乱中文字幕 | 国产精品久久久视频 | 久久草草热国产精品直播 | 亚洲黄色一级电影 | 九九欧美 | 国产精品热视频 | 99久久国产免费,99久久国产免费大片 | 国产一级一片免费播放放 | 亚洲国产成人精品电影在线观看 | 欧美aa在线观看 | 毛片激情永久免费 | 欧美精品你懂的 | 天天做天天爱天天综合网 | 欧美,日韩 | 91污视频在线 | 亚洲日韩欧美视频 | 狂野欧美激情性xxxx | 国产精品刺激对白麻豆99 | 少妇搡bbb | 亚洲精品国偷拍自产在线观看蜜桃 | 精品专区一区二区 | 久久黄色成人 | 天天干天天做天天操 | 色亚洲网| 亚州视频在线 | 又粗又长又大又爽又黄少妇毛片 | 婷婷网站天天婷婷网站 | 中文一二区 | 久久午夜网 | 中文字幕 成人 | 在线观看中文字幕一区 | 久久看毛片| 国产免费一区二区三区网站免费 | 久久国产精品一区二区 | 69精品视频在线观看 | 欧美日韩国产mv | 久久人人爽视频 | 亚洲激情综合 | 国产亚洲精品久久网站 | 玖玖在线视频观看 | 亚洲综合五月 | 国产精品久久久久久久久久直播 | 亚洲成人网av | aⅴ精品av导航 | 成 人 免费 黄 色 视频 | 久久久综合九色合综国产精品 | 97狠狠操| 久久久免费播放 | 欧美二区在线播放 | 日本中文字幕电影在线免费观看 | 国产99精品在线观看 | 五月婷婷视频在线 | 久久激情网站 | 国产精品美女视频网站 | 亚洲视频免费在线 | 中午字幕在线 | 欧美一区二区三区在线视频观看 | 亚洲一区免费在线 | 久久五月情影视 | 国产亚洲精品久久久网站好莱 | 玖玖在线播放 | 99久久精品国产一区二区成人 | 在线va网站| 91入口在线观看 | 欧美国产不卡 | 欧美日韩在线观看一区二区三区 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 久久最新网址 | 在线免费黄色毛片 | 五月天综合在线 | 中文字幕成人在线观看 | 成人黄色在线 | 99热免费在线| 888av| 久久久久激情视频 | 激情久久综合网 | 免费观看福利视频 | 91漂亮少妇露脸在线播放 | 久久久www成人免费精品 | 黄色国产在线观看 | 色婷婷激情电影 | 91福利视频在线 | 日韩爱爱片 | 久精品在线 | 欧美乱淫视频 | 日韩a欧美 | 免费av大全 | 国产亚洲精品成人av久久ww | 国产一区二区在线观看免费 | 日韩mv欧美mv国产精品 | 国产九色在线播放九色 | 亚洲精品乱码久久久久久蜜桃91 | 国产尤物一区二区三区 | 99久久99热这里只有精品 | 国产一级特黄毛片在线毛片 | 亚洲精品午夜国产va久久成人 | 天天激情在线 | 91在线91拍拍在线91 | 精品国产成人在线影院 | 69精品视频在线观看 | 国产精品18久久久久久久 | 国产免费嫩草影院 | 久久精品电影院 | 日韩欧美网站 | 精品一区二区三区四区在线 | 中文在线免费一区三区 | 久久老司机精品视频 | 亚洲高清网站 | 日韩视频www | 99亚洲天堂| 中文区中文字幕免费看 | 欧美日韩国产一区二区三区 | 夜夜爽www | 欧美精品一级视频 | 97人人添人澡人人爽超碰动图 | 五月天最新网址 | 黄色99视频 | av不卡免费看 | 日韩成人精品在线观看 | 欧美久久久久久久久中文字幕 | 久久免费视频8 | 美女视频又黄又免费 | 五月婷婷狠狠 | 免费人成网ww44kk44 | 天天要夜夜操 | 欧美日本三级 | 欧美一级片免费在线观看 | 久久久视频在线 | 午夜精品久久一牛影视 | 亚洲免费小视频 | 久人人 | 亚洲黄色一级视频 | 国产日韩精品久久 | 欧美aaaxxxx做受视频 | 欧美久久久久久久久久久久久 | 日韩色av色资源 | 狠狠躁日日躁狂躁夜夜躁av | 国内精品久久久久久久久 | 天天操夜夜操 | 亚洲精品国产片 | 超碰在线免费97 | 久久九九久久精品 | 日b视频在线观看网址 | 麻豆视频在线免费观看 | 在线观看的a站 | 日日狠狠| 国产1级视频 | 超碰电影在线观看 | 久久国产精品免费 | 国产精品永久免费在线 | 天天操天天怕 | 亚洲视频在线免费观看 | av超碰在线观看 | 亚洲日本成人 | 国产精品久久久久久久久久ktv | 久操伊人| 91入口在线观看 | 日韩精品视频免费看 | 国产玖玖在线 | 色综合欧洲 | 国产精品嫩草影院123 | 日韩免费福利 | 国产精品视频大全 | 亚洲国产精品一区二区久久,亚洲午夜 | 欧美九九九 | 国产成人综合精品 | 精品国产aⅴ一区二区三区 在线直播av | 天天综合网入口 | 国产精品欧美久久久久久 | 女人18精品一区二区三区 | 国产成人精品一区二区三区在线 | 亚洲激情六月 | 在线观看免费中文字幕 | 国产黄色片免费在线观看 | 成人黄色大片网站 | 日韩午夜视频在线观看 | 免费看的黄网站软件 | 一区二区三区四区在线免费观看 | 91桃色免费观看 | 91大神一区二区三区 | 亚洲一级黄色av | 欧美日韩一区二区三区在线观看视频 | 久草在线视频精品 | 中文字幕免费看 | 97免费中文视频在线观看 | 狠狠狠干 | 99色在线观看 | 狠狠狠色丁香婷婷综合久久五月 | 国产网红在线观看 | 欧美日韩在线免费观看 | 精品人人爽 | av观看久久久 | 成人黄色在线观看视频 | 日日夜夜人人天天 | 激情www| www.香蕉视频 | 97久久精品午夜一区二区 | 国产成人精品午夜在线播放 | 久久精品国产成人精品 | 中文字幕av免费观看 | 色中文字幕在线观看 | 久久精品在线 | 久草在线免 | 天堂麻豆 | 国产精品普通话 | 超碰免费成人 | 欧美午夜精品久久久久 | 久久精品美女 | 国产成人精品av久久 | 99精品视频在线播放免费 | 久久午夜色播影院免费高清 | 久久调教视频 | 亚洲黄色免费观看 | 日本久久免费电影 | 久久99亚洲精品久久 | 成人亚洲综合 | 少妇搡bbb| 日本少妇高清做爰视频 | 免费视频成人 | avav99| 免费在线观看av电影 | 久久亚洲区 | 久久精品资源 | 国产精品久久久久久69 | 久久国产精品免费一区 | 久操久| 中文字幕在线免费97 | 又色又爽又黄高潮的免费视频 | 日本大片免费观看在线 | 2019中文字幕第一页 | 欧美国产视频在线 | 精品少妇一区二区三区在线 | 中文资源在线播放 | 国产看片网站 | 欧美三级免费 | 91精品国自产在线观看 | 国产精品亚州 | 国产精品成人自产拍在线观看 | 亚洲精品国产欧美在线观看 | 96香蕉视频 | 在线亚洲高清视频 | 婷婷六月色| 国产免费观看高清完整版 | 国产精品第2页 | 玖玖国产精品视频 | 亚洲精品在线免费播放 | 久久电影网站中文字幕 | 99久久精品费精品 | 日韩欧美在线观看一区 | 国产日韩欧美在线观看视频 | 国产一级h| 色综合久久综合中文综合网 | 日本中文字幕免费观看 | 国产精品视频免费在线观看 | 91九色视频在线播放 | 色网站在线免费观看 | 欧美三级高清 | 91高清视频 | 激情久久综合 | 国产精品福利视频 | 亚洲成a人片在线www | 激情视频网页 | 字幕网av| 字幕网在线观看 | 最新超碰在线 | av女优中文字幕在线观看 | 激情电影在线观看 | 亚洲精品在| 在线观看国产福利片 | 91高清一区 | 欧美激情精品久久久久久免费 | 96久久精品| 亚洲永久字幕 | 色香蕉网| 国产又粗又硬又爽视频 | 亚洲国产视频直播 | 精品久久久成人 | 亚洲国产日韩在线 | 午夜视频免费 | 激情五月在线 | 国产精品久久在线观看 | 黄色资源网站 | 欧美成人影音 | 夜夜骑天天操 | 五月婷婷开心 | 黄色小网站在线观看 | 色中文字幕在线观看 | 久久五月婷婷丁香社区 | 999视频网 | 91最新网址在线观看 | av成人免费在线 | 蜜臀av性久久久久av蜜臀三区 | av成人免费在线观看 | 视频在线日韩 | 91香蕉亚洲精品 | 国产人成一区二区三区影院 | 天天射色综合 | 免费v片| 九九免费在线看完整版 | 国产精品永久免费在线 | 国产999精品久久久久久绿帽 | 国产午夜精品一区二区三区四区 | 91在线看片 | 男女视频久久久 | 日韩一区二区在线免费观看 | 中文字幕在线播放日韩 | 4438全国亚洲精品在线观看视频 | 亚洲精品美女 | 麻豆系列在线观看 | 午夜免费福利片 | 亚洲www天堂com | 日韩精品欧美一区 | 伊人久久五月天 | 国产精品都在这里 | 亚洲91视频 | 特黄特色特刺激视频免费播放 | 男女视频91| 欧美大荫蒂xxx | 射射射av| 成年人国产在线观看 | 精品产品国产在线不卡 | 国产成人精品av在线 | 成 人 黄 色 片 在线播放 | 婷婷精品国产欧美精品亚洲人人爽 | 久久精品播放 | 手机成人av| 久久综合九色九九 | 久草免费福利在线观看 | 亚洲久草在线视频 | 国产成人精品久 | 日韩在线三区 | av在线免费播放 | 九九视频免费观看视频精品 | 日韩有码在线播放 | 国产精品一区欧美 | 国产精品一区二区免费 | 西西4444www大胆艺术 | 一级黄色av | 97超视频| 久久亚洲影视 | 国产精品自产拍在线观看蜜 | 国产又粗又长的视频 | 天堂成人在线 | 五月婷婷丁香在线观看 | 久久久久麻豆v国产 | 91九色视频在线播放 | 欧美91片 | 成人a免费看 | 在线免费黄网站 | 国产精品成久久久久 | 国产日韩欧美精品在线观看 | av播放在线 | 亚洲国产中文在线 | 中文字幕免费观看全部电影 | 亚洲国产中文在线观看 | 波多野结衣精品 | 亚洲在线a| 亚洲精品国产麻豆 | 成在线播放| 少妇bbw搡bbbb搡bbb | 国产精品久久三 | 天天操天天爱天天爽 | 国产免费视频在线 | 色综合亚洲精品激情狠狠 | 日韩一区正在播放 | 精品一区久久 | 久久免费视频1 | 亚洲一区二区精品视频 | 狠狠色丁香九九婷婷综合五月 | 激情久久五月天 | 亚洲高清视频在线观看免费 | avcom在线| 免费人成在线观看 | 四虎在线永久免费观看 | 亚洲精品视频网址 | 香蕉视频色 | 99精品视频一区二区 | 国产黑丝一区二区三区 | 91成人免费观看视频 | 中文乱码视频在线观看 | 91av看片| 一区二区三区福利 | 国产一级免费在线 | 久草视频视频在线播放 | 久久免费国产电影 | 免费进去里的视频 | 91精品国产麻豆国产自产影视 | 欧美性大战久久久久 | 亚洲黄色软件 | 国产xx在线 | 天天干夜夜干 | 福利网址在线观看 | 国产成人精品一区一区一区 | 麻豆网站免费观看 | 韩国在线视频一区 | 亚洲成人国产 | 国产毛片在线 | 国产精品国产自产拍高清av | 午夜av日韩| 一区二区久久久久 | 久久久久亚洲精品成人网小说 | 毛片随便看 | 婷婷久久一区二区三区 | 天天做天天爱天天综合网 | 国内视频一区二区 | 国产成人三级一区二区在线观看一 | 免费在线成人 | 91精品网站在线观看 | 在线播放 亚洲 | 97人人添人澡人人爽超碰动图 | 2020天天干天天操 | 97久久精品午夜一区二区 | 久久免费观看视频 | 久久av中文字幕片 | 97精品视频在线播放 | 在线视频一区二区 | 日韩欧美xx | 国产 在线 日韩 | 国产91成人在在线播放 | 五月天色综合 | 国产精品 999| 四川妇女搡bbbb搡bbbb搡 | 免费福利视频网 | 日韩伦理片一区二区三区 | 欧美a级在线免费观看 | 在线观看的av网站 | 免费日韩 精品中文字幕视频在线 | av成人在线电影 | www.国产精品 | 美女免费视频网站 | 又污又黄的网站 | 日韩欧美在线高清 | 99热 精品在线 | 日日精品 | 黄色av电影在线 | 国产精品成人在线 | 天天操天天操天天操天天操天天操 | 色插综合 | 色综合天天天天做夜夜夜夜做 | 日韩激情av在线 | 精品国产99国产精品 | 黄色一集片 | 日韩高清在线看 | 一区二区伦理 | 欧美福利网址 | 开心激情综合网 | 玖玖视频免费在线 | 久久理论电影网 | 91九色在线播放 | 欧美成年人在线视频 | 国产毛片在线 | 久久久99国产精品免费 | 欧美精品v国产精品 | 成年人免费av | 又黄又爽又刺激 | 国产小视频你懂的在线 | 一区二区三区高清 | 91精品国产高清自在线观看 | 国产九色视频在线观看 | 射射射综合网 | 中文字幕乱码日本亚洲一区二区 | 久久综合九色99 | 97在线观看视频免费 | 日韩中文字幕网站 | 国产精品尤物 | 久久不卡免费视频 | 亚洲视频axxx| av电影免费在线播放 | 91亚洲欧美 | 久久精品亚洲一区二区三区观看模式 | 97人人模人人爽人人少妇 | 国产成人性色生活片 | 久久久久久综合 | 毛片888| 亚洲一级影院 | 亚洲区视频在线观看 | 91精品久久久久 | 久久日本视频 | 激情在线免费视频 | 日韩欧美在线观看一区二区 | 超碰在线观看97 | 色综合久久久久综合99 | 久久久观看| 免费的黄色的网站 | 欧美最猛性xxxxx(亚洲精品) | 91看片在线观看 | 日操操 | 综合色狠狠| 91视频免费播放 | 国产日韩欧美自拍 | 亚洲更新最快 | 欧美成人aa | 91精品国产麻豆 | 亚洲另类视频在线观看 | a久久久久| 国产亚州av | 国产在线 一区二区三区 | 亚洲最大的av网站 | 国产亚洲精品bv在线观看 | 伊人久久国产精品 | 欧美成人性战久久 | 国产99久久久国产精品成人免费 | 国语黄色片 | 成人在线视频在线观看 | 999久久久久久| 精品国产aⅴ麻豆 | 欧美日韩性视频在线 | 免费观看的黄色片 | 99久久99热这里只有精品 | 国产免费中文字幕 | 国产 欧美 日产久久 | 亚洲成av人片一区二区梦乃 | 亚洲免费高清视频 | 久久精品视频网站 | 成人国产精品入口 | 日本精品中文字幕在线观看 | 视频一区二区在线 | 制服丝袜在线91 | 天天综合网国产 | 天天天色综合a | 国内揄拍国内精品 | 中文字幕4| 色综合www | 在线99热| 日韩mv欧美mv国产精品 | 91麻豆国产福利在线观看 | 久久久久久久久久网站 | 91精品毛片 | 欧美日韩免费观看一区二区三区 | 欧美精品久久久久久久久久丰满 | 日本中文不卡 | 久久精品国产免费观看 | 在线播放一区二区三区 | 午夜av在线免费 | 在线视频观看成人 | 成人久久18免费网站图片 | 国产日韩视频在线播放 | 狠狠狠综合 | 91视频这里只有精品 | 亚洲日本va午夜在线电影 | 韩国在线视频一区 | 九九九视频精品 | 国产一区免费在线 | 日韩r级电影在线观看 | 亚洲精品资源在线观看 | 国产精品成人a免费观看 | 日韩国产高清在线 | 国产欧美久久久精品影院 | 日韩精品一区二区三区视频播放 | 午夜国产福利在线 | 久久神马影院 | 亚洲第一久久久 | 开心色激情网 | 国产精品美| 啪啪小视频网站 | 亚洲少妇久久 | 99这里只有精品99 | 9在线观看免费高清完整版在线观看明 | 欧美日韩伦理在线 | 91麻豆精品国产自产 | 韩国av免费在线 | 亚洲激情五月 | 国产91免费观看 | 免费网站在线观看成人 | 日韩av一区二区三区在线观看 | 国产裸体无遮挡 | 人人擦| 国产成人免费在线观看 | 亚洲欧美一区二区三区孕妇写真 | 日韩精品一区二区不卡 | 国产精品亚洲综合久久 | 亚洲一区二区三区精品在线观看 | 国内精品久久久久久久久久久久 | 久久激情视频网 | 久久综合福利 | 91视频免费播放 | 97精品国产97久久久久久粉红 | 成人超碰在线 | 久久久午夜精品理论片中文字幕 | 香蕉色综合| 久久国产视屏 | 日本一区二区不卡高清 | 国产精品不卡在线 | 4hu视频 | 综合五月| av看片在线观看 | 97狠狠操 | 日韩av黄 | 久久一精品 | 女人高潮特级毛片 | 免费视频在线观看网站 | 亚洲少妇xxxx | 99久久婷婷国产综合精品 | 在线观看成人一级片 | 国产99久久久久 | 高清av影院 | 欧美xxxxx在线视频 | 欧美日韩一区二区免费在线观看 | 国产专区欧美专区 | 天天爽天天爽夜夜爽 | 国产又粗又硬又长又爽的视频 | 久久a级片 | 99久久er热在这里只有精品15 | 亚洲成人软件 |