亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > SQL Server > 正文

SQL Server中關(guān)于基數(shù)估計計算預(yù)估行數(shù)的一些方法探討

2024-08-31 01:04:52
字體:
供稿:網(wǎng)友

關(guān)于SQL Server 2014中的基數(shù)估計,官方文檔Optimizing Your Query Plans with the SQL Server 2014 Cardinality Estimator里有大量細(xì)節(jié)介紹,但是全部是英文,估計也沒有幾個人仔細(xì)閱讀。那么SQL Server 2014中基數(shù)估計的預(yù)估行數(shù)到底是怎么計算的呢? 有哪一些規(guī)律呢?我們下面通過一些例子來初略了解一下,下面測試案例僅供參考,如有不足或膚淺的地方,敬請指教!

下面實驗測試的環(huán)境主要為SQL Server 2014 SP2 (Standard Edition (64-bit)) 具體版本號為12.0.5000.0 ,如有在其它版本測試,后面會做具體說明。如下所示,我們先創(chuàng)建一個測試表并插入一些測試數(shù)據(jù)后,方便后面的測試工作。

IF EXISTS(SELECT 1 FROM sys.objects WHERE type='U' AND name='TEST_ESTIMATED_ROW')BEGIN DROP TABLE TEST_ESTIMATED_ROW;ENDIF NOT EXISTS(SELECT 1 FROM sys.objects WHERE type='U' AND name='TEST_ESTIMATED_ROW')BEGIN  CREATE TABLE TEST_ESTIMATED_ROW  (   ID  INT,   NAME VARCHAR(24)  )ENDGODECLARE @Index INT =1;WHILE @Index <= 100BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(10, 'id is 10'); SET @Index+=1;ENDGODECLARE @Index INT =1;WHILE @Index <= 200BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(20, 'id is 20'); SET @Index+=1;ENDGODECLARE @Index INT =1;WHILE @Index <= 300BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(30, 'id is 30'); SET @Index+=1;ENDGODECLARE @Index INT =1;WHILE @Index <= 400BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(40, 'id is 40'); SET @Index+=1;ENDGODECLARE @Index INT =1;WHILE @Index <= 500BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(50, 'id is 50'); SET @Index+=1;ENDGOCREATE INDEX IX_TEST_ESTIMATED_ROW_N1 ON TEST_ESTIMATED_ROW(ID);GO

我們來看看這個表的統(tǒng)計信息以及直方圖內(nèi)容。

DBCC SHOW_STATISTICS ('dbo.TEST_ESTIMATED_ROW','IX_TEST_ESTIMATED_ROW_N1');GO

SQL Server,基數(shù)估計算法

SQL Server中有兩種謂詞:過濾謂詞和連接謂詞 。 我們先來看看過濾謂詞的基數(shù)估計(預(yù)估行數(shù)),測試過程,如果要保持測試的公正性或不被其他因素影響,你可以使用下面的DBCC命令來排除干擾,如下例子所示:

DBCC FREEPROCCACHE;  --從執(zhí)行計劃緩沖區(qū)刪除所有緩存的執(zhí)行計劃GODBCC DROPCLEANBUFFERS;  --從緩沖池中刪除所有緩存,清除緩沖區(qū)GOSELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = 10;GO

SQL Server,基數(shù)估計算法

(注意,執(zhí)行時請勾選包含實際執(zhí)行計劃按鈕)如上所示,預(yù)估行數(shù)(Estimated Number of Rows)為100,跟實際行數(shù)一致。當(dāng)然你換其他值,例如20, 30, 40 ,50,其預(yù)估行數(shù)(Estimated Number of Rows)跟實際行數(shù)都是正確的(SQL SERVER 2012中測試結(jié)果也相同)。那么如果我換一個不存在的值呢?預(yù)估行數(shù)會是多少呢?

SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = 4;GO

SQL Server,基數(shù)估計算法

如上所示,預(yù)估行數(shù)(Estimated Number of Rows)為1. 你換其他任何不存在的值,預(yù)估行數(shù)(Estimated Number of Rows)都為1。這個跟沿用了老的基數(shù)評估:超出統(tǒng)計信息范圍,那么老的基數(shù)評估就認(rèn)為不存在,評估行數(shù)為1。很顯然,對于沒有超出統(tǒng)計信息范疇的,但是確實不存在的記錄,其預(yù)估行數(shù)(Estimated Number of Rows)也是1,這個基數(shù)估計確實是合理,也是正確的。那么如果我使用變量呢?這個預(yù)估行數(shù)(Estimated Number of Rows)又會是什么值呢? 

DECLARE @SID INT = 11; --換任何值都可以SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = @SID;GO

SQL Server,基數(shù)估計算法

如上截圖所示,實際執(zhí)行計劃的預(yù)估行數(shù)(Estimated Number of Rows)是300, 那么如何計算來的呢? 其實你可以根據(jù)公式來計算, 如果不相信,你可以構(gòu)造各種案例測試驗證一下就能得到答案了. 

  [Row Sampled ]* [ALL density ] = 1500 * 0.2 = 300 也就是統(tǒng)計信息中抽樣總行數(shù)*All Density(統(tǒng)計信息對象中各列的每個前綴的密度) 

如果你加上OPTION(RECOMPILE), 那么預(yù)估行數(shù)(Estimated Number of Rows)又會變成1 

DECLARE @SID INT = 11; SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = @SID OPTION(RECOMPILE)GO

SQL Server,基數(shù)估計算法

如果你賦予@SID值為20,并加上OPTION(RECOMPILE)時,那么預(yù)估行數(shù)(Estimated Number of Rows)就會變成EQ_ROWS的值了

DECLARE @SID INT = 20; SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = @SID OPTION(RECOMPILE)GO

SQL Server,基數(shù)估計算法

接下來,我們修改一下SQL語句,將查詢條件從等于符號改為大于符號,如下所示:

DECLARE @SID INT = 11;SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID > @SID;GO

SQL Server,基數(shù)估計算法

如上所示,預(yù)估行數(shù)(Estimated Number of Rows)變?yōu)榱?50,那么這個值是怎么計算得來的呢?

計算公式是: [Row Sampled ] * 0.3(30%)

1500 *0.3= 450

肯定會有人問,你怎么知道是 [Row Sampled ] * 0.3 呢? 不會是你逆推的吧。 不錯,這里是一個推測(網(wǎng)上也有不少資料都確認(rèn)是0.3,權(quán)且當(dāng)做計算公式中的一個常量),而且也做了不少測試,確實就是30%。例如你將@SID賦值為41,預(yù)估行數(shù)(Estimated Number of Rows)依然為450,如果你懷疑是緩存的執(zhí)行計劃緣故,你可以先清空緩存的執(zhí)行計劃,結(jié)果依然如此。根據(jù)我的測試,不管你給@SID賦予任何值,預(yù)估行數(shù)(Estimated Number of Rows)全部為450

DBCC FREEPROCCACHE;GODBCC DROPCLEANBUFFERS;GODECLARE @SID INT = 41;SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID > @SID;GO

 SQL Server,基數(shù)估計算法

如果SQL加上 OPTION(RECOMPILE) ,然后@SID賦予RANGE_HI_KEY里的值,那么預(yù)估行數(shù)(Estimated Number of Rows)又是如何計算的呢?

DECLARE @SID INT = 20;SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID > @SID OPTION(RECOMPILE);GO

SQL Server,基數(shù)估計算法

這個1200 是這樣計算的,如下所示,大于20的RANGE_HI_KEY有30 , 40, 50 ,他們對應(yīng)的EQ_ROWS值相加 300+ 400 + 500 =1200, 不信你可以測試一下,將@SID賦予30,那么預(yù)估行數(shù)(Estimated Number of Rows)就會變成900. SQL Server,基數(shù)估計算法

那么我們再修改一下SQL查詢語句,例如,我們要做一個區(qū)間查詢,預(yù)估行數(shù)(Estimated Number of Rows)又會有什么變化呢?

DBCC FREEPROCCACHE;GODBCC DROPCLEANBUFFERS;GODECLARE @Min_Value INT = 20;DECLARE @Max_Value INT = 50;SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID > @Min_Value AND ID < @Max_ValueGO

SQL Server,基數(shù)估計算法

如上所示,預(yù)估行數(shù)(Estimated Number of Rows)為246.475 這個值怎么來的呢?其實它是這樣計算的:

Selectivity of most selective predicate * Square root of (selectivity of second most selective predicate) * Total number of rowsSELECT 0.3*SQRT(0.3)*1500 --246.475150877325 --0.3是計算規(guī)則里面的一個常量

那么如果我在SQL Server 2012中執(zhí)行該SQL語句或者使用查詢跟蹤標(biāo)記9481來關(guān)閉新的基數(shù)評估,數(shù)據(jù)庫優(yōu)化器使用老的基數(shù)評估,你會發(fā)現(xiàn)預(yù)估行數(shù)(Estimated Number of Rows)為135了。如下所示:

DBCC FREEPROCCACHE;GODBCC DROPCLEANBUFFERS;GODECLARE @Min_Value INT = 20;DECLARE @Max_Value INT = 50;SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID > @Min_Value AND ID < @Max_ValueOPTION (QUERYTRACEON 9481);GO

SQL Server,基數(shù)估計算法

這里的計算公式是

((Estimated number of rows for first predicate) *(Estimated number of rows for second predicate)) /Total number of rows(0.3*1500)*(0.3*1500)/1500 = 0.09*1500 = 135 

那么現(xiàn)在我們往表TEST_ESTIMATED_ROW里面插入50條記錄,此時這個數(shù)據(jù)量是不會觸發(fā)統(tǒng)計信息更新的,而此時ID=55的值超出了直方圖中的RANG_HI_KY的最大值50,也就是說直方圖中沒有統(tǒng)計這些新插入的數(shù)據(jù),那這種情形稱作升序鍵問題(ascending key problem)。在更統(tǒng)計信息新前就對這些數(shù)據(jù)運(yùn)行查詢,就會發(fā)生此類問題。

DECLARE @Index INT =1;WHILE @Index <= 50BEGIN INSERT INTO TEST_ESTIMATED_ROW VALUES(55, 'id is 50'); SET @Index+=1;ENDGO

那么再來看看下面SQL的預(yù)估行數(shù)(Estimated Number of Rows),如下所示:

DBCC FREEPROCCACHE;GODBCC DROPCLEANBUFFERS;GOSELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = 55;GO

SQL Server,基數(shù)估計算法

那么預(yù)估行數(shù)(Estimated Number of Rows)為39.37 是怎么計算來的呢?其實這個問題就是http://www.cnblogs.com/wy123/p/6770258.html這篇博客里面提出的問題,先前++C++他在群里面討論了一下。

Optimizing Your Query Plans with the SQL Server 2014 Cardinality Estimator里面介紹,這種是基數(shù)估計的計算公式為 [All density] * [Rows Sampled] 。但是實際測試發(fā)現(xiàn)這個例子并不是如此,那么我們先來親自測試一下白皮書文檔里面的例子(注意,數(shù)據(jù)庫實例是SQL Server 2014,AdventureWorks2012的兼容級別為120),看看文檔里面的例子是否正確。

SELECT [SalesOrderID], [OrderDate] FROM Sales.[SalesOrderHeader]WHERE [OrderDate] = '2005-07-01 00:00:00.000';SELECT [s].[object_id],  [s].[name],  [s].[auto_created]FROM sys.[stats] AS sINNER JOIN sys.[stats_columns] AS [sc]  ON [s].[stats_id] = [sc].[stats_id] AND   [s].[object_id] = [sc].[object_id]WHERE [s].[object_id] = OBJECT_ID('Sales.SalesOrderHeader') AND  COL_NAME([s].[object_id], [sc].[column_id]) = 'OrderDate';

可以看到OrderDate的統(tǒng)計信息為_WA_Sys_00000003_4B7734FF

 
SQL Server,基數(shù)估計算法

DBCC SHOW_STATISTICS('Sales.SalesOrderHeader', _WA_Sys_00000003_4B7734FF);

SQL Server,基數(shù)估計算法

從上可以看到最后統(tǒng)計信息更新時,采集的RANGE_HI_KEY的最大值為2008-07-31 00:00:00,那么我們插入50條記錄,此時這個數(shù)據(jù)量并不會觸發(fā)統(tǒng)計信息更新。

INSERT INTO Sales.[SalesOrderHeader] ( [RevisionNumber], [OrderDate],           [DueDate], [ShipDate], [Status],           [OnlineOrderFlag],           [PurchaseOrderNumber],           [AccountNumber], [CustomerID],           [SalesPersonID], [TerritoryID],           [BillToAddressID], [ShipToAddressID],           [ShipMethodID], [CreditCardID],           [CreditCardApprovalCode],           [CurrencyRateID], [SubTotal],           [TaxAmt], [Freight], [Comment] )VALUES ( 3, '2014-02-02 00:00:00.000', '5/1/2014', '4/1/2014', 5, 0, 'SO43659', 'PO522145787',29825, 279, 5, 985, 985, 5, 21, 'Vi84182', NULL, 250.00,25.00, 10.00, '' );GO 50 -- INSERT 50 rows, representing very recent data, with a current OrderDate value

然后我們開啟SQL跟蹤標(biāo)志9481,你會發(fā)現(xiàn)下面SQL的預(yù)估行數(shù)為1。因為此時優(yōu)化器采用老的基數(shù)估計。 

SELECT [SalesOrderID], [OrderDate] FROM Sales.[SalesOrderHeader]WHERE [OrderDate] = '2014-02-02 00:00:00.000'OPTION (QUERYTRACEON 9481); -- CardinalityEstimationModelVersion 70

SQL Server,基數(shù)估計算法

取消SQL跟蹤標(biāo)志時,數(shù)據(jù)庫使用新的基數(shù)估計時,預(yù)估函數(shù)變?yōu)榱?7.9938

DBCC FREEPROCCACHE;GODBCC DROPCLEANBUFFERS;GOSELECT [SalesOrderID], [OrderDate] FROM Sales.[SalesOrderHeader]WHERE [OrderDate] = '2014-02-02 00:00:00.000'

SQL Server,基數(shù)估計算法

SQL Server,基數(shù)估計算法

31465 *0.0008896797 ~=27.9937717605 ~= 27.9938 (四舍五入)

白皮書里的例子確實是如此,但是最上面那個例子,不清楚預(yù)估行數(shù)是如何計算的,盡管做了一些推測,但是在其它例子中始終不能驗證。不知是這個白皮書有誤還是SQL Server的基數(shù)估計做了調(diào)整, 還是說基數(shù)估計(CE)的算法遠(yuǎn)遠(yuǎn)不止這么簡單?我在這個問題上糾結(jié)了兩天,依然沒有搞清楚!在測試、推測過程中,我發(fā)現(xiàn)一個新的問題:當(dāng)表里面新增了數(shù)據(jù),那么之前的測試列子結(jié)果是否還是一樣呢?答案是不一樣了。如下所示:

SELECT * FROM dbo.TEST_ESTIMATED_ROW WHERE ID = 10;GO

SQL Server,基數(shù)估計算法

預(yù)估函數(shù)從100變?yōu)榱?03.333, 這個是怎么計算來的呢? 個人推測是這樣得來的(如下所示)。

SELECT 1550*(100.0/1500) --~= 103.332300 

也就是說升序鍵問題(ascending key problem)也會影響預(yù)估函數(shù)。上面都是簡單SQL的預(yù)估行數(shù)(Estimated Number of Rows)的推演、實際情況中,SQL要比這個復(fù)雜得多,那么在復(fù)雜情況下,例如多個過濾謂詞的情況下,基數(shù)估計又是怎樣預(yù)估行數(shù)的呢?由于前面例子構(gòu)造的比較簡單,不適合后面的演示,那么我們就用Optimizing Your Query Plans with the SQL Server 2014 Cardinality Estimator里的例子來簡單演示一下: 

USE [AdventureWorks2012];GOSELECT  [AddressID],  [AddressLine1],  [AddressLine2]FROM Person.[Address]WHERE [StateProvinceID] = 9 AND   [City] = N'Burbank' AND   [PostalCode] = N'91502'OPTION (QUERYTRACEON 9481); -- CardinalityEstimationModelVersion 70GO

SQL Server,基數(shù)估計算法

如下所示,過濾謂詞[StateProvinceID]、[City]、 [PostalCode]對應(yīng)的統(tǒng)計信息分別為IX_Address_StateProvinceID、_WA_Sys_00000004_164452B1、_WA_Sys_00000006_164452B1。

SELECT [s].[object_id],    [s].[name],    [s].[auto_created],    COL_NAME([s].[object_id], [sc].[column_id]) AS [col_name]FROM  sys.[stats] AS sINNER JOIN sys.[stats_columns] AS [sc]    ON [s].[stats_id] = [sc].[stats_id] AND      [s].[object_id] = [sc].[object_id]WHERE  [s].[object_id] = OBJECT_ID('Person.Address');

SQL Server,基數(shù)估計算法

DBCC SHOW_STATISTICS ('Person.Address', _WA_Sys_00000004_164452B1); -- City

SQL Server,基數(shù)估計算法

SELECT 196.0/19614 ~= 0.0099928DBCC SHOW_STATISTICS ('Person.Address', IX_Address_StateProvinceID); -- StateProvinceID

SQL Server,基數(shù)估計算法

SELECT 4564.0/19614 ~= 0.2326909DBCC SHOW_STATISTICS ('Person.Address', _WA_Sys_00000006_164452B1); -- PostalCode

SQL Server,基數(shù)估計算法

SELECT 194.0/19614 ~= 0.0098908 --記錄

從SQL Server 7 ~ SQL Server 2012, 如果查詢條件中,兩個或多個謂詞使用AND聯(lián)結(jié),那么各個謂詞的選擇率Si的乘積將作為查詢預(yù)估函數(shù)的選擇率

(S1 * S2 * S3....*Sn)(S1 * S2 * S3....*Sn) *(Rows Sampled) SELECT 0.0098908 * -- PostalCode predicate selectivity    0.0099928 * -- City predicate selectivity    0.2326909 * -- StateProvinceID predicate selectivity    19614;   -- Table cardinality

其計算結(jié)果為0.451091024458953138624 ,它低于1行。所以查詢優(yōu)化器使用估計的最小行數(shù) (1)。下面看看SQL Server 2014中新的基數(shù)估計是如何計算預(yù)估行數(shù)的。

SELECT  [AddressID],  [AddressLine1],  [AddressLine2]FROM Person.[Address]WHERE [StateProvinceID] = 9 AND   [City] = N'Burbank' AND   [PostalCode] = N'91502'GO

SQL Server,基數(shù)估計算法

那么新的基數(shù)估計(SQL Server 2014)的預(yù)估行數(shù)(Estimated Number of Rows)13.4692是怎么計算來的呢? 其實它們是選擇率使用下面這樣一個公式,其中p0 < p1 < p2 < p3 < p4

SQL Server,基數(shù)估計算法

SELECT 0.0098908        * -- PostalCode predicate selectivity    SQRT(0.0099928)     * -- City predicate selectivity    SQRT(SQRT(0.2326909))  * -- StateProvinceID predicate selectivity    19614; -- Table cardinality

計算結(jié)果為13.4690212669225 ~= 13.4692 是否還是有一些差別呢?你使用下面SQL對比,就會發(fā)現(xiàn),其實原因是小數(shù)點后精確位數(shù)和四舍五入導(dǎo)致的。具體我也不知道計算估計精確位數(shù)。

SQL Server,基數(shù)估計算法

那么OR Selectivity又是如何計算的,我們先來看看老的基數(shù)估計是是如何計算的,如下例子所示:

USE [AdventureWorks2012];GOSELECT  [AddressID],     [AddressLine1],     [AddressLine2]FROM Person.[Address]WHERE ([StateProvinceID] = 9 OR   [City] = N'Burbank' )AND   [PostalCode] = N'91502'OPTION (QUERYTRACEON 9481); -- CardinalityEstimationModelVersion 70

SQL Server,基數(shù)估計算法

0.0098908 -- PostalCode predicate selectivity0.0099928 -- City predicate selectivity0.2326909 -- StateProvinceID predicate selectivity

計算公式:(S1 + S2) – (S1 * S2) ,那么(S1 + S2) – (S1 * S2) 計算的值為

(0.0099928 + 0.2326909) - (0.0099928 * 0.2326909) ~= 0.24035846637448 

然后和AND操作,我們執(zhí)行SQL Server 2014以前的AND的選擇性是這樣計算的S1 * S2

0.0098908 * ((0.0099928 + 0.2326909) - (0.0099928 * 0.2326909)) ~= 0.002377337519216706784

最后的計算結(jié)果如下:

0.002377337519216706784 *19614 ~= 46.629098101916486861376 ~= 46.6296 (注意這個誤差是因為精確小數(shù)位數(shù)和四舍五入造成的) 

那么我們再來看看SQL Server 2014下OR Selectivity的計算公式

USE [AdventureWorks2012];GOSELECT  [AddressID],     [AddressLine1],     [AddressLine2]FROM Person.[Address]WHERE ([StateProvinceID] = 9 OR   [City] = N'Burbank' )AND   [PostalCode] = N'91502'

SQL Server,基數(shù)估計算法

那么這個預(yù)估行數(shù)(Estimated Number of Rows)是怎么算出來的呢? Paul White 的博客介紹,是通過下面這樣計算來的。

0.0098908 -- PostalCode predicate selectivity0.0099928 -- City predicate selectivity0.2326909 -- StateProvinceID predicate selectivity 

A OR B = NOT (( NOT A) AND (NOT B)) 就是說A OR B 和 NOT (( NOT A) AND (NOT B)) 是等價的。 

那么就可以這么推算,最后的預(yù)估行數(shù)(Estimated Number of Rows)計算結(jié)果為94.3525, 跟結(jié)果94.3515有細(xì)微差別(這個是因為浮點數(shù)精度和四舍五入造成的)

SELECT 1- (1- 0.2326909)*SQRT(( 1-0.0099928)) ~= 0.236534308898679SELECT 0.009891 *SQRT(1- (1- 0.2326909)*SQRT(( 1-0.0099928)) )*19614 ~= 94.3525070823501 ~= 94.3515

上面是關(guān)于SQL Server中的基數(shù)估計(CE)如何計算預(yù)估行數(shù)的一些初步的探討和認(rèn)識,糾結(jié)我的問題到目前還沒有弄清楚。雖然有點遺憾,但是在測試過程,發(fā)現(xiàn)去探究這些規(guī)律是一件非常有意思的事情.

以上所述是小編給大家介紹的SQL Server中關(guān)于基數(shù)估計計算預(yù)估行數(shù)的一些方法探討,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對VeVb武林網(wǎng)網(wǎng)站的支持!

 

注:相關(guān)教程知識閱讀請移步到MSSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
欧美日韩免费做爰视频| 美丽的姑娘在线观看免费动漫| av亚洲精华国产精华精华| 欧美国产乱视频| 欧美视频在线视频| 久久99精品久久久久婷婷| 久久久久五月天| 91成人精品观看| 国产精品麻豆网站| 欧美专区第二页| 国产色片在线观看| 国产精品一码二码三码在线| 亚洲国产精品狼友在线观看| 国产日韩在线不卡| 色五月激情五月| 香蕉久久免费电影| 亚洲精品在线观| 亚洲天堂2021av| 狠狠综合久久av一区二区| 在线播放/欧美激情| 91se在线| 久久婷婷五月综合色国产香蕉| 亚洲最大成人综合| 国产精品视频久久一区| 亚洲黄色在线观看视频| 黄色av成人| 国产精品久久久久久久久久白浆| 最新日本在线观看| 蜜桃传媒视频第一区入口在线看| 日韩精品电影网| 欧美性色xo影院| 久久99久久99小草精品免视看| 中文字幕人妻一区二区| 青青草视频成人| 在线免费国产视频| 搜成人激情视频| 无码人妻精品一区二区| 亚洲日本无吗高清不卡| 欧美乱做爰xxxⅹ久久久| 开心激情五月婷婷| 亚洲资源在线看| 91国拍精品国产粉嫩亚洲一区| 国产成人在线免费| 日本大片在线看黄a∨免费| 精品国产三级电影在线观看| 国产成人小视频在线观看| 裸体裸乳免费看| 8x8ⅹ拨牐拨牐拨牐在线观看| 中文字幕人妻色偷偷久久| 国产激情视频一区二区三区| 国产精品久久免费视频| 精品美女被调教视频大全网站| 日本成人免费视频| 国产噜噜噜噜噜久久久久久久久| 欧美午夜电影在线观看| 尤物在线精品视频| 日韩久久精品一区二区三区| 激情视频小说图片| 亚洲AV无码国产成人久久| 国产伦精品一区二区三区在线播放| 亚洲性xxxx| 中文字幕在线视频一区二区三区| 色丁香久综合在线久综合在线观看| 91久久精品国产91久久性色tv| 三级av在线| 国产欧美日本亚洲精品一4区| www.欧美黄色| 中文字幕人妻一区二区三区视频| caoporn免费在线| 亚洲天堂久久新| 久久综合一区二区三区| 精品人妻在线播放| 国产精品成人观看视频国产奇米| 一二三四视频在线社区中文字幕2| 9l视频自拍九色9l视频成人| 超碰在线中文字幕| 久久久国产精彩视频美女艺术照福利| 久久国产成人精品| 亚洲精品国产精品乱码| 国产导航在线| 91精品久久久久久久久久久久久久| 精品一区二区三区的国产在线播放| 成人午夜在线视频| 中文字幕av免费观看| 成人福利一区二区| 日韩 欧美 视频| 国产精品一品| 欧美成人精品| 伊人精品久久久久7777| 国产亚洲aⅴaaaaaa毛片| 99视频精品全部免费在线| 丰满少妇一区二区三区专区| 国产日产精品一区二区三区四区的观看方式| 国产91色在线|| 先锋影音成人资源| 在线成人午夜影院| 天堂成人娱乐在线视频免费播放网站| 真实原创一区二区影院| 99re在线视频播放| 麻豆电影在线| 亚洲乱码国产乱码精品精大量| 一本加勒比波多野结衣| av在线播放免费| 亚洲精品在线观看免费| 超碰一区二区三区| 欧美三级免费| 五月婷婷深爱五月| 亚洲三级在线| 性一交一乱一伧老太| 久久久久久久国产精品| 午夜性色一区二区三区免费视频| 99国产超薄肉色丝袜交足的后果| 一级日本免费的| 91午夜在线观看| 亚洲午夜国产一区99re久久| 日本一区二区三级电影在线观看| 色视频在线观看免费| 久久99精品久久久久久噜噜| 欧美色图另类小说| 日韩欧美精品免费| 亚洲无线观看| 亚洲一二三四视频| 国产在线观看欧美| 精品精品欲导航| 久久久免费人体| 亚洲亚洲人成综合网络| 黄色av网站在线播放| 欧美日韩免费观看一区| 亚洲国产精品资源| 国产成+人+综合+亚洲欧美| 中文字幕在线观看91| 亚洲影视资源| 国产一区二区区别| 国产一区二区在线播放视频| 亚洲bbw性色大片| 欧美一区二区公司| 国产a级一级片| 给个网站可以在线观看你懂的| 国产精品久久久久999| 91精品成人久久| 久久―日本道色综合久久| 亚洲一区电影| 永久免费未视频| 福利一区二区在线| 高清视频一区二区三区| 成人3d动漫一区二区三区| 暖暖影院日本高清...免费| 九九视频精品免费| 国产精品乱码| 战狼4完整免费观看在线播放版| 亚洲欧美日本一区| 国产高潮在线| 色婷婷亚洲一区二区三区| 精品国自产拍在线观看| 国产91av在线| 精品一区二区三区在线视频| 2019男人天堂| 国产91免费观看| 男女一区二区三区免费| 无码人妻黑人中文字幕| 97超碰中文字幕| 天天影视综合| 蜜桃精品久久久久久久免费影院| 国产一区二区三区四| 日韩精品久久久免费观看| 精品国产亚洲一区二区三区大结局| 综合久久久久久| 亚洲女子a中天字幕| 在线亚洲不卡| av漫画网站| www.夜夜操| av电影资源| 色噜噜日韩精品欧美一区二区| 纪美影视在线观看电视版使用方法| 久青青在线观看视频国产| 日本乱理伦在线| 国产精品视频公开费视频| 北条麻妃在线| 欧美国产综合色视频| 中国一级黄色录像| 日韩一级片在线播放| 久久久精品美女| japanese色国产在线看视频| 51国偷自产一区二区三区| 国产高清一级毛片在线不卡| 四虎永久在线精品免费一区二区| 欧产日产国产精品视频| 春意影院免费入口| 97久久精品人人做人人爽| 亚洲综合中文字幕在线观看| 99久久激情视频| 久久久久人妻一区精品色欧美| 中文子幕无线码一区tr| 国产精品传媒入口麻豆| 免费电影一区二区三区| 国产无遮挡又黄又爽免费网站| 日韩激情视频在线| 成人全视频高清免费观看| 岛国毛片av在线| 亚洲一区二区欧美| 久久狠狠亚洲综合| 成人免费高清完整版在线观看| 亚洲视频高清| 国产在线精品一区二区夜色| 亚洲精品一级二级三级| 天天干在线视频论坛| 久久精品国产精品青草| 欧美日韩三级| 国产精品23p| 三级av免费观看| 91麻豆精品一二三区在线| 欧美一区二区三区免费观看视频| 伊人亚洲福利一区二区三区| 丰满人妻av一区二区三区| 九色自拍论坛| 久久久久久久久久看片| 干日本少妇视频| 欧美日韩影院| 丁香花在线影院| 久久精品国产亚洲blacked| 国产日韩视频在线播放| 午夜啪啪免费视频| 蜜桃tv在线播放| 亚洲欧美一区二区三区极速播放| 亚洲美女免费在线| palipali轻量版永久网页入口| 国产精品久久777777毛茸茸| 免费高清一区二区三区| www.国产三级| 91高清免费视频| 香蕉免费一区二区三区在线观看| 免费黄视频在线观看| 午夜精品久久久久久久| 免费又爽又黄禁片视频1000片| 国产成人精品日本亚洲| 九九爱免费视频在线观看| 日韩成人免费电影| 九九热青青草| 超鹏97在线| 99视频在线播放| 激情综合五月网| 亚洲老妇xxxxxx| 秋霞午夜av一区二区三区| 91大神在线观看线路一区| 国产精品涩涩涩视频网站| 久久久黄色大片| 欧美人与性动交α欧美精品济南到| www.98色噜噜噜| 国产极品久久久久久久久波多结野| 99在线观看免费视频精品观看| 欧美在线1区| 一级黄色免费片| 国产不卡一区视频| 欧美一区激情视频在线观看| 美女性感视频久久| 精品伊人久久大线蕉色首页| 国产三级三级看三级| 成人p站proumb入口| 性欧美69式xxxxx| 91麻豆精品久久毛片一级| 成人蜜臀av电影| 国产精品黄色| 国产狂喷白浆在线观看视频| 色综合中文网| 国产精品美女视频网站| 牛夜精品久久久久久久99黑人| 女海盗2成人h版中文字幕| 美女视频网站久久| 色一情一乱一伦一区二区三区| 中文字幕日韩有码| 污污的网站18| 91久久精品久久国产性色也91| ·天天天天操| 成人久久18免费网站漫画| 97精品电影院| 国产在线高清视频| 欧美高清视频免费观看| 国产igao激情在线入口| 一起草在线视频| 欧美精品一区二区三区中文字幕| 国产精品www网站| 草莓视频末满18勿| 国产又粗又猛又爽又黄的网站| 亚洲亚洲精品在线观看| 成人拍拍拍免费视频网站| 116美女写真午夜一级久久| 国产精品久线观看视频| 中文字幕日韩av综合精品| 欧美激情性爽国产精品17p| 国产对白videos麻豆高潮| 色94色欧美sute亚洲13| 好吊色欧美一区二区三区视频| 99精品视频免费版的特色功能| 午夜久久久久久| www狠狠操| 色诱av手机版| www.国产三级| 国产精品国产福利国产秒拍| 最近2019中文免费高清视频观看www99| 免费观看在线一区二区三区| 搡的我好爽在线观看免费视频| 性感美女激情视频在线观看| 国产精品亚洲第一区在线暖暖韩国| 欧美日韩亚洲综合在线| 一区二区三区网址| 欧美性猛片aaaaaaa做受| 91亚洲午夜精品久久久久久| 大香伊人久久| 日韩视频―中文字幕| 精品国产伦理网| 日本高清视频免费观看| 男人的天堂在线视频| 亚洲一级片av| 欧美日韩国产二区| 美女精品一区最新中文字幕一区二区三区| 亚洲黄色免费观看| 高清免费成人av| 中文字幕一区二区三区5566| 国产香蕉视频在线看| 黄色小视频免费看| 亚州欧美一区三区三区在线| 日韩美女一区二区三区| 伊人久久亚洲影院| www.浪潮av.com| 丰满熟妇人妻中文字幕| 欧洲在线视频一区| 成人福利视频在线| 日韩伦人妻无码|