校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PostgreSQL 對IN,EXISTS,ANY/ALL,JOIN的sql優(yōu)化方案

PostgreSQL 對IN,EXISTS,ANY/ALL,JOIN的sql優(yōu)化方案

熱門標(biāo)簽:江蘇400電話辦理官方 天津開發(fā)區(qū)地圖標(biāo)注app 移動外呼系統(tǒng)模擬題 電銷機(jī)器人能補(bǔ)救房產(chǎn)中介嗎 地圖標(biāo)注要花多少錢 廣州電銷機(jī)器人公司招聘 電話機(jī)器人怎么換人工座席 400電話申請客服 濟(jì)南外呼網(wǎng)絡(luò)電話線路

測試環(huán)境:

postgres=# select version();       
                         version                        
---------------------------------------------------------------------------------------------------------
 PostgreSQL 11.9 on x86_64-pc-linux-gnu, compiled by gcc (GCC) 4.8.5 20150623 (Red Hat 4.8.5-39), 64-bit
(1 row) 
postgres=#

數(shù)據(jù)準(zhǔn)備:

$ pgbench -i -s 10
postgres=# \d
       List of relations
 Schema |    Name    | Type | Owner 
--------+------------------+-------+----------
 public | pgbench_accounts | table | postgres
 public | pgbench_branches | table | postgres
 public | pgbench_history | table | postgres
 public | pgbench_tellers | table | postgres
(4 rows)
 
postgres=# select * from pgbench_accounts limit 1;
 aid | bid | abalance |                    filler                    
-----+-----+----------+--------------------------------------------------------------------------------------
  1 |  1 |    0 |                                          
(1 row)
 
postgres=# select * from pgbench_branches limit 1;
 bid | bbalance | filler
-----+----------+--------
  1 |    0 |
(1 row)
 
postgres=# select * from pgbench_history limit 1;
 tid | bid | aid | delta | mtime | filler
-----+-----+-----+-------+-------+--------
(0 rows)
 
postgres=# select * from pgbench_tellers limit 1;
 tid | bid | tbalance | filler
-----+-----+----------+--------
  1 |  1 |    0 |
(1 row)
 
postgres=# select * from pgbench_branches;
 bid | bbalance | filler
-----+----------+--------
  1 |    0 |
  2 |    0 |
  3 |    0 |
  4 |    0 |
  5 |    0 |
  6 |    0 |
  7 |    0 |
  8 |    0 |
  9 |    0 |
 10 |    0 |
(10 rows)
 
postgres=# update pgbench_branches set bbalance=4500000 where bid in (4,7);
UPDATE 2
postgres=#

IN語句

查詢要求:找出那些余額(balance)大于0的每個分支(branch)在表在pgbench_accounts中有多少個賬戶

1.使用IN子句 

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  bid IN ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 )
GROUP BY
  bid;
 

2.使用ANY子句

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  bid = ANY ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 )
GROUP BY
  bid;

  

3.使用EXISTS子句

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  EXISTS ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 AND pgbench_accounts.bid = pgbench_branches.bid )
GROUP BY
  bid;

  

4.使用INNER JOIN

SELECT
  count( aid ),a.bid
FROM
  pgbench_accounts a
  JOIN pgbench_branches b ON a.bid = b.bid
WHERE
  b.bbalance > 0
GROUP BY
  a.bid;

在完成這個查詢要求的時候,有人可能會假設(shè)exists和inner join性能可能會更好,因?yàn)樗麄兛梢允褂脙杀磉B接的邏輯和優(yōu)化。而IN和ANY子句需要使用子查詢。

然而,PostgreSQL(10版本之后)已經(jīng)智能的足以對上面四種寫法產(chǎn)生相同的執(zhí)行計劃!

所有上面的寫法都會產(chǎn)生相同的執(zhí)行計劃:

                                      QUERY PLAN                                      
------------------------------------------------------------------------------------------------------------------------------------------------------------------
 Finalize GroupAggregate (cost=23327.73..23330.26 rows=10 width=12) (actual time=97.199..99.014 rows=2 loops=1)
  Group Key: a.bid
  -> Gather Merge (cost=23327.73..23330.06 rows=20 width=12) (actual time=97.191..99.006 rows=6 loops=1)
     Workers Planned: 2
     Workers Launched: 2
     -> Sort (cost=22327.70..22327.73 rows=10 width=12) (actual time=93.762..93.766 rows=2 loops=3)
        Sort Key: a.bid
        Sort Method: quicksort Memory: 25kB
        Worker 0: Sort Method: quicksort Memory: 25kB
        Worker 1: Sort Method: quicksort Memory: 25kB
        -> Partial HashAggregate (cost=22327.44..22327.54 rows=10 width=12) (actual time=93.723..93.727 rows=2 loops=3)
           Group Key: a.bid
           -> Hash Join (cost=1.14..22119.10 rows=41667 width=8) (actual time=24.024..83.263 rows=66667 loops=3)
              Hash Cond: (a.bid = b.bid)
              -> Parallel Seq Scan on pgbench_accounts a (cost=0.00..20560.67 rows=416667 width=8) (actual time=0.023..43.151 rows=333333 loops=3)
              -> Hash (cost=1.12..1.12 rows=1 width=4) (actual time=0.027..0.028 rows=2 loops=3)
                 Buckets: 1024 Batches: 1 Memory Usage: 9kB
                 -> Seq Scan on pgbench_branches b (cost=0.00..1.12 rows=1 width=4) (actual time=0.018..0.020 rows=2 loops=3)
                    Filter: (bbalance > 0)
                    Rows Removed by Filter: 8
 Planning Time: 0.342 ms
 Execution Time: 99.164 ms
(22 rows)

那么,我們是否可以得出這樣的結(jié)論:我們可以隨意地編寫查詢,而PostgreSQL的智能將會處理其余的問題?!

等等!

如果我們考慮排除情況,事情會變得不同。

排除查詢

查詢要求:找出那些余額(balance)不大于0的每個分支(branch)在表在pgbench_accounts中有多少個賬戶

1.使用NOT IN

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  bid NOT IN ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 )
GROUP BY
  bid;

執(zhí)行計劃:

                                    QUERY PLAN                                    
----------------------------------------------------------------------------------------------------------------------------------------------------------
 Finalize GroupAggregate (cost=23645.42..23647.95 rows=10 width=12) (actual time=128.606..130.502 rows=8 loops=1)
  Group Key: pgbench_accounts.bid
  -> Gather Merge (cost=23645.42..23647.75 rows=20 width=12) (actual time=128.598..130.490 rows=24 loops=1)
     Workers Planned: 2
     Workers Launched: 2
     -> Sort (cost=22645.39..22645.42 rows=10 width=12) (actual time=124.960..124.963 rows=8 loops=3)
        Sort Key: pgbench_accounts.bid
        Sort Method: quicksort Memory: 25kB
        Worker 0: Sort Method: quicksort Memory: 25kB
        Worker 1: Sort Method: quicksort Memory: 25kB
        -> Partial HashAggregate (cost=22645.13..22645.23 rows=10 width=12) (actual time=124.917..124.920 rows=8 loops=3)
           Group Key: pgbench_accounts.bid
           -> Parallel Seq Scan on pgbench_accounts (cost=1.13..21603.46 rows=208333 width=8) (actual time=0.078..83.134 rows=266667 loops=3)
              Filter: (NOT (hashed SubPlan 1))
              Rows Removed by Filter: 66667
              SubPlan 1
               -> Seq Scan on pgbench_branches (cost=0.00..1.12 rows=1 width=4) (actual time=0.020..0.021 rows=2 loops=3)
                  Filter: (bbalance > 0)
                  Rows Removed by Filter: 8
 Planning Time: 0.310 ms
 Execution Time: 130.620 ms
(21 rows)
 
postgres=#

2.使用>ALL

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  bid > ALL ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 )
GROUP BY
  bid;

執(zhí)行計劃:

                                     QUERY PLAN                                    
------------------------------------------------------------------------------------------------------------------------------------------------------------
 Finalize GroupAggregate (cost=259581.79..259584.32 rows=10 width=12) (actual time=418.220..419.913 rows=8 loops=1)
  Group Key: pgbench_accounts.bid
  -> Gather Merge (cost=259581.79..259584.12 rows=20 width=12) (actual time=418.212..419.902 rows=24 loops=1)
     Workers Planned: 2
     Workers Launched: 2
     -> Sort (cost=258581.76..258581.79 rows=10 width=12) (actual time=413.906..413.909 rows=8 loops=3)
        Sort Key: pgbench_accounts.bid
        Sort Method: quicksort Memory: 25kB
        Worker 0: Sort Method: quicksort Memory: 25kB
        Worker 1: Sort Method: quicksort Memory: 25kB
        -> Partial HashAggregate (cost=258581.50..258581.60 rows=10 width=12) (actual time=413.872..413.875 rows=8 loops=3)
           Group Key: pgbench_accounts.bid
           -> Parallel Seq Scan on pgbench_accounts (cost=0.00..257539.83 rows=208333 width=8) (actual time=0.054..367.244 rows=266667 loops=3)
              Filter: (SubPlan 1)
              Rows Removed by Filter: 66667
              SubPlan 1
               -> Materialize (cost=0.00..1.13 rows=1 width=4) (actual time=0.000..0.001 rows=2 loops=1000000)
                  -> Seq Scan on pgbench_branches (cost=0.00..1.12 rows=1 width=4) (actual time=0.001..0.001 rows=2 loops=337880)
                     Filter: (bbalance > 0)
                     Rows Removed by Filter: 8
 Planning Time: 0.218 ms
 Execution Time: 420.035 ms
(22 rows) 
postgres=#

3.使用NOT EXISTS

SELECT
  count( aid ),bid
FROM
  pgbench_accounts
WHERE
  NOT EXISTS ( SELECT bid FROM pgbench_branches WHERE bbalance > 0 AND pgbench_accounts.bid = pgbench_branches.bid )
GROUP BY
  bid;

執(zhí)行計劃:

                                      QUERY PLAN                                     
----------------------------------------------------------------------------------------------------------------------------------------------------------------
 Finalize GroupAggregate (cost=28327.72..28330.25 rows=10 width=12) (actual time=152.024..153.931 rows=8 loops=1)
  Group Key: pgbench_accounts.bid
  -> Gather Merge (cost=28327.72..28330.05 rows=20 width=12) (actual time=152.014..153.917 rows=24 loops=1)
     Workers Planned: 2
     Workers Launched: 2
     -> Sort (cost=27327.70..27327.72 rows=10 width=12) (actual time=147.782..147.786 rows=8 loops=3)
        Sort Key: pgbench_accounts.bid
        Sort Method: quicksort Memory: 25kB
        Worker 0: Sort Method: quicksort Memory: 25kB
        Worker 1: Sort Method: quicksort Memory: 25kB
        -> Partial HashAggregate (cost=27327.43..27327.53 rows=10 width=12) (actual time=147.732..147.737 rows=8 loops=3)
           Group Key: pgbench_accounts.bid
           -> Hash Anti Join (cost=1.14..25452.43 rows=375000 width=8) (actual time=0.134..101.884 rows=266667 loops=3)
              Hash Cond: (pgbench_accounts.bid = pgbench_branches.bid)
              -> Parallel Seq Scan on pgbench_accounts (cost=0.00..20560.67 rows=416667 width=8) (actual time=0.032..45.174 rows=333333 loops=3)
              -> Hash (cost=1.12..1.12 rows=1 width=4) (actual time=0.036..0.037 rows=2 loops=3)
                 Buckets: 1024 Batches: 1 Memory Usage: 9kB
                 -> Seq Scan on pgbench_branches (cost=0.00..1.12 rows=1 width=4) (actual time=0.025..0.027 rows=2 loops=3)
                    Filter: (bbalance > 0)
                    Rows Removed by Filter: 8
 Planning Time: 0.322 ms
 Execution Time: 154.040 ms
(22 rows) 
postgres=#

4.使用LEFT JOIN和IS NULL

SELECT
  count( aid ),a.bid
FROM
  pgbench_accounts a
  LEFT JOIN pgbench_branches b ON a.bid = b.bid AND b.bbalance > 0
WHERE
  b.bid IS NULL
GROUP BY
  a.bid;

執(zhí)行計劃:

                                      QUERY PLAN                                      
------------------------------------------------------------------------------------------------------------------------------------------------------------------
 Finalize GroupAggregate (cost=28327.72..28330.25 rows=10 width=12) (actual time=145.298..147.096 rows=8 loops=1)
  Group Key: a.bid
  -> Gather Merge (cost=28327.72..28330.05 rows=20 width=12) (actual time=145.288..147.083 rows=24 loops=1)
     Workers Planned: 2
     Workers Launched: 2
     -> Sort (cost=27327.70..27327.72 rows=10 width=12) (actual time=141.883..141.887 rows=8 loops=3)
        Sort Key: a.bid
        Sort Method: quicksort Memory: 25kB
        Worker 0: Sort Method: quicksort Memory: 25kB
        Worker 1: Sort Method: quicksort Memory: 25kB
        -> Partial HashAggregate (cost=27327.43..27327.53 rows=10 width=12) (actual time=141.842..141.847 rows=8 loops=3)
           Group Key: a.bid
           -> Hash Anti Join (cost=1.14..25452.43 rows=375000 width=8) (actual time=0.087..99.535 rows=266667 loops=3)
              Hash Cond: (a.bid = b.bid)
              -> Parallel Seq Scan on pgbench_accounts a (cost=0.00..20560.67 rows=416667 width=8) (actual time=0.025..44.337 rows=333333 loops=3)
              -> Hash (cost=1.12..1.12 rows=1 width=4) (actual time=0.026..0.027 rows=2 loops=3)
                 Buckets: 1024 Batches: 1 Memory Usage: 9kB
                 -> Seq Scan on pgbench_branches b (cost=0.00..1.12 rows=1 width=4) (actual time=0.019..0.020 rows=2 loops=3)
                    Filter: (bbalance > 0)
                    Rows Removed by Filter: 8
 Planning Time: 0.231 ms
 Execution Time: 147.180 ms
(22 rows) 
postgres=#

NOT IN 和 > ALL生成執(zhí)行計劃都包含了一個子查詢。他們是各自獨(dú)立的。

而NOT EXISTS和LEFT JOIN生成了相同的執(zhí)行計劃。

這些hash連接(或hash anti join)是完成查詢要求的最靈活的方式。這也是推薦exists或join的原因。因此,推薦使用exists或join的經(jīng)驗(yàn)法則是有效的。

但是,我們繼續(xù)往下看! 即使有了子查詢執(zhí)行計劃,NOT IN子句的執(zhí)行時間也會更好?

是的。PostgreSQL做了出色的優(yōu)化,PostgreSQL將子查詢計劃進(jìn)行了hash處理。因此PostgreSQL對如何處理IN子句有了更好的理解,這是一種邏輯思維方式,因?yàn)楹芏嗳藘A向于使用IN子句。子查詢返回的行很少,但即使子查詢返回幾百行,也會發(fā)生同樣的情況。

但是,如果子查詢返回大量行(幾十萬行)怎么辦?讓我們嘗試一個簡單的測試:

CREATE TABLE t1 AS
SELECT * FROM generate_series(0, 500000) id;
 
CREATE TABLE t2 AS
SELECT (random() * 4000000)::integer id
FROM generate_series(0, 4000000);
 
ANALYZE t1;
ANALYZE t2;
 
EXPLAIN SELECT id
FROM t1
WHERE id NOT IN (SELECT id FROM t2);

執(zhí)行計劃:

    QUERY PLAN                 
--------------------------------------------------------------------------------
 Gather (cost=1000.00..15195064853.01 rows=250000 width=4)
  Workers Planned: 1
  -> Parallel Seq Scan on t1 (cost=0.00..15195038853.01 rows=147059 width=4)
     Filter: (NOT (SubPlan 1))
     SubPlan 1
      -> Materialize (cost=0.00..93326.01 rows=4000001 width=4)
         -> Seq Scan on t2 (cost=0.00..57700.01 rows=4000001 width=4)
(7 rows)
 
postgres=#

這里,執(zhí)行計劃將子查詢進(jìn)行了物化。代價評估變成了15195038853.01。(PostgreSQL的默認(rèn)設(shè)置,如果t2表的行低于100k,會將子查詢進(jìn)行hash)。這樣就會嚴(yán)重影響性能。因此,對于那種子查詢返回的行數(shù)很少的場景,IN子句可以起到很好的作用。

其它注意點(diǎn)

有的!在我們用不同的方式寫查詢的時候,可能有數(shù)據(jù)類型的轉(zhuǎn)換。

比如,語句:

EXPLAIN ANALYZE SELECT * FROM emp WHERE gen = ANY(ARRAY['M', 'F']);

就會發(fā)生隱式的類型轉(zhuǎn)換:

Seq Scan on emp (cost=0.00..1.04 rows=2 width=43) (actual time=0.023..0.026 rows=3 loops=1)
 Filter: ((gen)::text = ANY ('{M,F}'::text[]))

這里的(gen)::text就發(fā)生了類型轉(zhuǎn)換。如果在大表上,這種類型轉(zhuǎn)換的代價會很高,因此,PostgreSQL對IN子句做了更好的處理。

EXPLAIN ANALYZE SELECT * FROM emp WHERE gen IN ('M','F');
 
 Seq Scan on emp (cost=0.00..1.04 rows=3 width=43) (actual time=0.030..0.034 rows=3 loops=1)
  Filter: (gen = ANY ('{M,F}'::bpchar[]))

將IN子句轉(zhuǎn)換成了ANY子句,沒有對gen列進(jìn)行類型轉(zhuǎn)換。而是將M\F轉(zhuǎn)成了bpchar(內(nèi)部等價于char)

總結(jié)

簡單來說,exists和直接join表通常比較好。

很多情況下,PostgreSQL將IN子句換成被hash的子計劃。在一些特殊場景下,IN可以獲得更好的執(zhí)行計劃。

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL利用遞歸優(yōu)化求稀疏列唯一值的方法
  • PostgreSQL刪除更新優(yōu)化操作
  • Postgresql排序與limit組合場景性能極限優(yōu)化詳解
  • postgresql通過索引優(yōu)化查詢速度操作
  • postgresql關(guān)于like%xxx%的優(yōu)化操作

標(biāo)簽:杭州 海西 濮陽 榆林 辛集 溫州 寶雞 昭通

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PostgreSQL 對IN,EXISTS,ANY/ALL,JOIN的sql優(yōu)化方案》,本文關(guān)鍵詞  PostgreSQL,對,EXISTS,ANY,ALL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PostgreSQL 對IN,EXISTS,ANY/ALL,JOIN的sql優(yōu)化方案》相關(guān)的同類信息!
  • 本頁收集關(guān)于PostgreSQL 對IN,EXISTS,ANY/ALL,JOIN的sql優(yōu)化方案的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    美女性感视频久久| 日本二三区不卡| a美女胸又www黄视频久久| 在线播放欧美女士性生活| 国产亚洲成aⅴ人片在线观看| 亚洲大尺度视频在线观看| 国产91丝袜在线18| 欧美一区二区在线免费播放| 亚洲欧洲一区二区在线播放| 国产一区二区三区不卡在线观看| 欧美系列一区二区| 中文字幕人成不卡一区| 久久99蜜桃精品| 欧美偷拍一区二区| 亚洲精品国产无天堂网2021| 波多野结衣一区二区三区| 亚洲精品一区二区精华| 看片的网站亚洲| 91精品国产一区二区| 樱桃视频在线观看一区| 91色视频在线| 亚洲女人****多毛耸耸8| 丁香婷婷综合激情五月色| 日韩一区二区三区免费观看| 日韩电影在线一区二区| 欧美日韩成人在线一区| 亚洲一区在线观看视频| 91日韩精品一区| 亚洲丝袜另类动漫二区| 99久久精品免费看国产| 一区二区中文字幕在线| 99精品视频在线免费观看| 欧美极品aⅴ影院| 成人国产电影网| 国产精品久久久久久久久免费樱桃 | 精品裸体舞一区二区三区| 日本不卡一二三区黄网| 777亚洲妇女| 青青草成人在线观看| 日韩免费高清av| 国内精品伊人久久久久av一坑| 精品国偷自产国产一区| 国产精品资源在线看| 国产亚洲短视频| av网站免费线看精品| 亚洲欧美日韩中文字幕一区二区三区 | 67194成人在线观看| 午夜婷婷国产麻豆精品| 日韩一级片在线播放| 激情综合五月天| 国产精品麻豆欧美日韩ww| 在线免费观看日韩欧美| 丝袜国产日韩另类美女| 久久人人爽人人爽| 97精品电影院| 日韩有码一区二区三区| 26uuu欧美日本| av色综合久久天堂av综合| 五月天国产精品| 26uuu久久天堂性欧美| 暴力调教一区二区三区| 亚洲成在人线在线播放| 精品电影一区二区| 色综合久久久久久久久| 看国产成人h片视频| 国产精品国产自产拍高清av | 国产精品传媒在线| 欧洲生活片亚洲生活在线观看| 日韩国产在线一| 久久蜜桃av一区精品变态类天堂| 一本色道久久综合亚洲精品按摩| 毛片av一区二区三区| 亚洲欧洲一区二区在线播放| 91精品在线免费| 成人久久久精品乱码一区二区三区| 一区二区三区在线播放| 精品美女在线播放| 在线视频一区二区三区| 国产成人一级电影| 午夜激情一区二区| 中文字幕在线播放不卡一区| 在线综合视频播放| 色噜噜狠狠色综合欧洲selulu| 开心九九激情九九欧美日韩精美视频电影 | 久久在线免费观看| 在线一区二区三区| 国产精品一区二区91| 图片区小说区区亚洲影院| 国产精品免费网站在线观看| 欧美绝品在线观看成人午夜影视| 成人国产在线观看| 国模冰冰炮一区二区| 日韩av电影免费观看高清完整版 | 国产一区二区毛片| 亚洲国产视频直播| 国产精品伦一区二区三级视频| 日韩一区二区视频在线观看| 在线观看一区二区视频| 不卡视频一二三四| 国产精品资源站在线| 精品亚洲成a人在线观看| 污片在线观看一区二区| 亚洲va欧美va人人爽午夜| 亚洲人成伊人成综合网小说| 国产欧美一区二区精品婷婷| 精品欧美久久久| 91精品黄色片免费大全| 欧美肥胖老妇做爰| 欧美精品自拍偷拍| 欧美性xxxxx极品少妇| 色天使久久综合网天天| 91免费国产在线观看| 成人av免费在线观看| 成人免费观看视频| 成人av电影观看| 99久久免费精品高清特色大片| 成人午夜激情影院| www.久久精品| av成人动漫在线观看| 91在线无精精品入口| 色婷婷av一区二区三区大白胸| 在线欧美日韩国产| 精品视频在线免费看| 欧美久久久久久蜜桃| 欧美一区二区播放| 精品国产区一区| 久久久精品国产免费观看同学| 国产视频一区在线观看| 国产精品久久久久久久第一福利| 日韩毛片一二三区| 五月婷婷欧美视频| 老司机免费视频一区二区| 国产精品一区三区| av成人老司机| 91精品国产福利| 久久影院午夜片一区| 国产精品成人在线观看| 亚洲黄色av一区| 偷拍一区二区三区四区| 免费高清不卡av| 丁香亚洲综合激情啪啪综合| 在线国产电影不卡| 精品久久久久香蕉网| 国产精品久久久久影院亚瑟| 一区二区三区在线免费| 麻豆精品国产传媒mv男同| 国产不卡视频一区二区三区| 91在线一区二区| 91精品国产品国语在线不卡| 国产精品入口麻豆九色| 亚洲国产成人高清精品| 国产一区二区三区在线观看精品| 成人性视频免费网站| 欧美日本视频在线| 日本一区二区视频在线观看| 亚洲一区二区三区国产| 国产精品小仙女| 欧美三区免费完整视频在线观看| 精品国产一区二区亚洲人成毛片 | 久久国产精品99精品国产| 成人一级视频在线观看| 欧美精品亚洲一区二区在线播放| 久久精品一区八戒影视| 亚洲一区二区在线播放相泽| 国产黄人亚洲片| 欧美视频一区二区在线观看| 国产精品私人自拍| 日韩va欧美va亚洲va久久| 91麻豆免费观看| 久久久久国产免费免费| 国产一区二区不卡| 欧美性色欧美a在线播放| 国产嫩草影院久久久久| 美日韩一区二区三区| 色噜噜夜夜夜综合网| 欧美极品xxx| 国产自产高清不卡| 欧美精品少妇一区二区三区| 国产精品成人免费在线| 国产激情91久久精品导航| 欧美一区二区精品久久911| 一区二区三区精品在线| av在线一区二区三区| 久久伊人蜜桃av一区二区| 性做久久久久久| 欧美三级日韩在线| 夜夜精品视频一区二区| 91免费小视频| 最新成人av在线| 91网站最新地址| 18欧美亚洲精品| 99久久99久久精品国产片果冻| 久久久精品tv| 福利视频网站一区二区三区| 精品国产伦一区二区三区免费| 久久超级碰视频| 精品精品欲导航| 狠狠v欧美v日韩v亚洲ⅴ| 久久影院视频免费| 国产999精品久久久久久|