精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

看一遍就理解:Group By詳解

系統(tǒng)
日常開發(fā)中,我們經常會使用到group by。親愛的小伙伴,你是否知道group by的工作原理呢?group by和having有什么區(qū)別呢?group by的優(yōu)化思路是怎樣的呢?

前言

大家好,我是撿田螺的小男孩。

日常開發(fā)中,我們經常會使用到group by。親愛的小伙伴,你是否知道group by的工作原理呢?group by和having有什么區(qū)別呢?group by的優(yōu)化思路是怎樣的呢?使用group by有哪些需要注意的問題呢?本文將跟大家一起來學習,攻克group by~

  • 使用group by的簡單例子
  • group by 工作原理
  • group by + where 和 having的區(qū)別
  • group by 優(yōu)化思路
  • group by 使用注意點
  • 一個生產慢SQL如何優(yōu)化

1. 使用group by的簡單例子

group by一般用于分組統(tǒng)計,它表達的邏輯就是根據一定的規(guī)則,進行分組。我們先從一個簡單的例子,一起來復習一下哈。

假設用一張員工表,表結構如下:

  1. CREATE TABLE `staff` ( 
  2.   `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵id'
  3.   `id_card` varchar(20) NOT NULL COMMENT '身份證號碼'
  4.   `namevarchar(64) NOT NULL COMMENT '姓名'
  5.   `age` int(4) NOT NULL COMMENT '年齡'
  6.   `city` varchar(64) NOT NULL COMMENT '城市'
  7.   PRIMARY KEY (`id`) 
  8. ) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='員工表'

表存量的數據如下:

我們現(xiàn)在有這么一個需求:統(tǒng)計每個城市的員工數量。對應的 SQL 語句就可以這么寫:

  1. select city ,count(*) as num from staff group by city; 

執(zhí)行結果如下:

這條SQL語句的邏輯很清楚啦,但是它的底層執(zhí)行流程是怎樣的呢?

2. group by 原理分析

2.1 explain 分析

我們先用explain查看一下執(zhí)行計劃

  1. explain select city ,count(*) as num from staff group by city; 

Extra 這個字段的Using temporary表示在執(zhí)行分組的時候使用了臨時表

Extra 這個字段的Using filesort表示使用了排序

group by 怎么就使用到臨時表和排序了呢?我們來看下這個SQL的執(zhí)行流程

2.2 group by 的簡單執(zhí)行流程

  1. explain select city ,count(*) as num from staff group by city; 

我們一起來看下這個SQL的執(zhí)行流程哈

  • 創(chuàng)建內存臨時表,表里有兩個字段city和num;
  • 全表掃描staff的記錄,依次取出city = 'X'的記錄。
    • 判斷臨時表中是否有為 city='X'的行,沒有就插入一個記錄 (X,1);
    • 如果臨時表中有city='X'的行的行,就將x 這一行的num值加 1;

遍歷完成后,再根據字段city做排序,得到結果集返回給客戶端。

這個流程的執(zhí)行圖如下:

臨時表的排序是怎樣的呢?

就是把需要排序的字段,放到sort buffer,排完就返回。在這里注意一點哈,排序分全字段排序和rowid排序

  • 如果是全字段排序,需要查詢返回的字段,都放入sort buffer,根據排序字段排完,直接返回
  • 如果是rowid排序,只是需要排序的字段放入sort buffer,然后多一次回表操作,再返回。
  • 怎么確定走的是全字段排序還是rowid 排序排序呢?由一個數據庫參數控制的,max_length_for_sort_data

對排序有興趣深入了解的小伙伴,可以看我這篇文章哈。

看一遍就理解:order by詳解

3. where 和 having的區(qū)別

  • group by + where 的執(zhí)行流程
  • group by + having 的執(zhí)行流程
  • 同時有where、group by 、having的執(zhí)行順序

3.1 group by + where 的執(zhí)行流程

有些小伙伴覺得上一小節(jié)的SQL太簡單啦,如果加了where條件之后,并且where條件列加了索引呢,執(zhí)行流程是怎樣?

好的,我們給它加個條件,并且加個idx_age的索引,如下:

  1. select city ,count(*) as num from staff where age> 30 group by city; 
  2. //加索引 
  3. alter table staff add index idx_age (age); 

再來expain分析一下:

  1. explain select city ,count(*) as num from staff where age> 30 group by city; 

從explain 執(zhí)行計劃結果,可以發(fā)現(xiàn)查詢條件命中了idx_age的索引,并且使用了臨時表和排序

Using index condition:表示索引下推優(yōu)化,根據索引盡可能的過濾數據,然后再返回給服務器層根據where其他條件進行過濾。這里單個索引為什么會出現(xiàn)索引下推呢?explain出現(xiàn)并不代表一定是使用了索引下推,只是代表可以使用,但是不一定用了。大家如果有想法或者有疑問,可以加我微信討論哈。

執(zhí)行流程如下:

  • 創(chuàng)建內存臨時表,表里有兩個字段city和num;
  • 掃描索引樹idx_age,找到大于年齡大于30的主鍵ID
  • 通過主鍵ID,回表找到city = 'X'
    • 判斷臨時表中是否有為 city='X'的行,沒有就插入一個記錄 (X,1);
    • 如果臨時表中有city='X'的行的行,就將x 這一行的num值加 1;
  • 繼續(xù)重復2,3步驟,找到所有滿足條件的數據,
  • 最后根據字段city做排序,得到結果集返回給客戶端。

3.2 group by + having 的執(zhí)行

如果你要查詢每個城市的員工數量,獲取到員工數量不低于3的城市,having可以很好解決你的問題,SQL醬紫寫:

  1. select city ,count(*) as num from staff  group by city having num >= 3; 

查詢結果如下:

having稱為分組過濾條件,它對返回的結果集操作。

3.3 同時有where、group by 、having的執(zhí)行順序

如果一個SQL同時含有where、group by、having子句,執(zhí)行順序是怎樣的呢。

比如這個SQL:

  1. select city ,count(*) as num from staff  where age> 19 group by city having num >= 3; 
  • 執(zhí)行where子句查找符合年齡大于19的員工數據
  • group by子句對員工數據,根據城市分組。
  • 對group by子句形成的城市組,運行聚集函數計算每一組的員工數量值;
  • 最后用having子句選出員工數量大于等于3的城市組。

3.4 where + having 區(qū)別總結

  • having子句用于分組后篩選,where子句用于行條件篩選
  • having一般都是配合group by 和聚合函數一起出現(xiàn)如(count(),sum(),avg(),max(),min())
  • where條件子句中不能使用聚集函數,而having子句就可以。
  • having只能用在group by之后,where執(zhí)行在group by之前

4. 使用 group by 注意的問題

使用group by 主要有這幾點需要注意:

  • group by一定要配合聚合函數一起使用嘛?
  • group by的字段一定要出現(xiàn)在select中嘛
  • group by導致的慢SQL問題

4.1 group by一定要配合聚合函數使用嘛?

group by 就是分組統(tǒng)計的意思,一般情況都是配合聚合函數如(count(),sum(),avg(),max(),min())一起使用。

  • count() 數量
  • sum() 總和
  • avg() 平均
  • max() 最大值
  • min() 最小值

如果沒有配合聚合函數使用可以嗎?

我用的是Mysql 5.7 ,是可以的。不會報錯,并且返回的是,分組的第一行數據。

比如這個SQL:

  1. select city,id_card,age from staff group by  city; 

查詢結果是

大家對比看下,返回的就是每個分組的第一條數據

當然,平時大家使用的時候,group by還是配合聚合函數使用的,除非一些特殊場景,比如你想去重,當然去重用distinct也是可以的。

4.2 group by 后面跟的字段一定要出現(xiàn)在select中嘛。

不一定,比如以下SQL:

  1. select max(age)  from staff group by city; 

執(zhí)行結果如下:

分組字段city不在select 后面,并不會報錯。當然,這個可能跟不同的數據庫,不同的版本有關吧。大家使用的時候,可以先驗證一下就好。有一句話叫做,紙上得來終覺淺,絕知此事要躬行。

4.3 group by導致的慢SQL問題

到了最重要的一個注意問題啦,group by使用不當,很容易就會產生慢SQL 問題。因為它既用到臨時表,又默認用到排序。有時候還可能用到磁盤臨時表。

  • 如果執(zhí)行過程中,會發(fā)現(xiàn)內存臨時表大小到達了上限(控制這個上限的參數就是tmp_table_size),會把內存臨時表轉成磁盤臨時表。
  • 如果數據量很大,很可能這個查詢需要的磁盤臨時表,就會占用大量的磁盤空間。

這些都是導致慢SQL的x因素,我們一起來探討優(yōu)化方案哈。

5. group by的一些優(yōu)化方案

從哪些方向去優(yōu)化呢?

  • 方向1:既然它默認會排序,我們不給它排是不是就行啦。
  • 方向2:既然臨時表是影響group by性能的X因素,我們是不是可以不用臨時表?

我們一起來想下,執(zhí)行group by語句為什么需要臨時表呢?group by的語義邏輯,就是統(tǒng)計不同的值出現(xiàn)的個數。如果這個這些值一開始就是有序的,我們是不是直接往下掃描統(tǒng)計就好了,就不用臨時表來記錄并統(tǒng)計結果啦?

  • group by 后面的字段加索引
  • order by null 不用排序
  • 盡量只使用內存臨時表
  • 使用SQL_BIG_RESULT

5.1 group by 后面的字段加索引

如何保證group by后面的字段數值一開始就是有序的呢?當然就是加索引啦。

我們回到一下這個SQL

  1. select city ,count(*) as num from staff where age= 19 group by city; 

它的執(zhí)行計劃

如果我們給它加個聯(lián)合索引idx_age_city(age,city)

  1. alter table staff add index idx_age_city(age,city); 

再去看執(zhí)行計劃,發(fā)現(xiàn)既不用排序,也不需要臨時表啦。圖片

加合適的索引是優(yōu)化group by最簡單有效的優(yōu)化方式。

5.2 order by null 不用排序

并不是所有場景都適合加索引的,如果碰上不適合創(chuàng)建索引的場景,我們如何優(yōu)化呢?

如果你的需求并不需要對結果集進行排序,可以使用order by null。

  1. select city ,count(*) as num from staff group by city order by null 

執(zhí)行計劃如下,已經沒有filesort啦

5.3 盡量只使用內存臨時表

如果group by需要統(tǒng)計的數據不多,我們可以盡量只使用內存臨時表;因為如果group by 的過程因為內存臨時表放不下數據,從而用到磁盤臨時表的話,是比較耗時的。因此可以適當調大tmp_table_size參數,來避免用到磁盤臨時表。

5.4 使用SQL_BIG_RESULT優(yōu)化

如果數據量實在太大怎么辦呢?總不能無限調大tmp_table_size吧?但也不能眼睜睜看著數據先放到內存臨時表,隨著數據插入發(fā)現(xiàn)到達上限,再轉成磁盤臨時表吧?這樣就有點不智能啦。

因此,如果預估數據量比較大,我們使用SQL_BIG_RESULT 這個提示直接用磁盤臨時表。MySQl優(yōu)化器發(fā)現(xiàn),磁盤臨時表是B+樹存儲,存儲效率不如數組來得高。因此會直接用數組來存

示例SQl如下:

  1. select SQL_BIG_RESULT city ,count(*) as num from staff group by city; 

執(zhí)行計劃的Extra字段可以看到,執(zhí)行沒有再使用臨時表,而是只有排序

執(zhí)行流程如下:

  • 初始化 sort_buffer,放入city字段;
  • 掃描表staff,依次取出city的值,存入 sort_buffer 中;
  • 掃描完成后,對 sort_buffer的city字段做排序
  • 排序完成后,就得到了一個有序數組。
  • 根據有序數組,統(tǒng)計每個值出現(xiàn)的次數。

6. 一個生產慢SQL如何優(yōu)化

最近遇到個生產慢SQL,跟group by相關的,給大家看下怎么優(yōu)化哈。

表結構如下:

  1. CREATE TABLE `staff` ( 
  2.   `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵id'
  3.   `id_card` varchar(20) NOT NULL COMMENT '身份證號碼'
  4.   `namevarchar(64) NOT NULL COMMENT '姓名'
  5.   `status` varchar(64) NOT NULL COMMENT 'Y-已激活 I-初始化 D-已刪除 R-審核中'
  6.   `age` int(4) NOT NULL COMMENT '年齡'
  7.   `city` varchar(64) NOT NULL COMMENT '城市'
  8.   `enterprise_no` varchar(64) NOT NULL COMMENT '企業(yè)號'
  9.   `legal_cert_no` varchar(64) NOT NULL COMMENT '法人號碼'
  10.   PRIMARY KEY (`id`) 
  11. ) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='員工表'

查詢的SQL是這樣的:

  1. select * from t1 where status = #{status} group by #{legal_cert_no} 

我們先不去探討這個SQL的=是否合理。如果就是這么個SQL,你會怎么優(yōu)化呢?有想法的小伙伴可以留言討論哈,也可以加我微信加群探討。如果你覺得文章那里寫得不對,也可以提出來哈,一起進步,加油呀

參考與感謝

mySQL 45講 (https://time.geekbang.org/column/article/80477?cid=100020801)

本文轉載自微信公眾號「撿田螺的小男孩」,可以通過以下二維碼關注。轉載本文請聯(lián)系撿田螺的小男孩公眾號。

 

責任編輯:武曉燕 來源: 撿田螺的小男孩
相關推薦

2021-06-15 07:15:15

Oracle底層explain

2021-08-12 10:36:18

order byMySQL數據庫

2021-12-01 07:26:13

IO模型異步

2025-02-13 09:06:27

2024-03-26 07:59:32

IO模型多路復用

2024-03-12 08:20:57

零拷貝存儲開發(fā)

2021-10-07 20:12:03

MVCC事務原理

2020-02-09 17:30:54

反轉鏈表程序員節(jié)點

2019-03-19 14:11:44

VLANLANMAC

2022-05-08 23:05:38

Route-Poli路由策略

2023-09-12 07:31:45

HashMap線程

2022-08-26 10:41:03

指針C語言

2019-09-19 08:04:40

網絡七層模型TCPUDP

2021-10-08 07:53:01

事務隔離級別

2023-08-14 07:49:42

AI訓練

2023-01-10 19:47:47

Redis原理多線程

2017-12-26 14:17:24

潤乾報表

2015-10-10 11:10:24

重敲代碼拷貝粘貼

2021-11-25 08:16:46

Wi-FiWi-Fi 6路由Wi-Fi 5

2021-03-11 07:14:01

Epoll原理線程
點贊
收藏

51CTO技術棧公眾號

国产成人精品福利| 国产原创在线观看| 麻豆久久婷婷| 中文字幕免费精品一区| 福利片一区二区三区| 最新超碰在线| 91在线看国产| 国产有码在线一区二区视频| 免费在线看黄网址| 欧美亚洲色图校园春色| 欧美精品欧美精品系列| www.av毛片| 成年人免费在线视频| 国产东北露脸精品视频| 98视频在线噜噜噜国产| 国产精品久久久视频| 超碰97成人| 欧美日韩国产大片| 青青草成人免费在线视频| 幼a在线观看| 99精品欧美一区| 91在线观看免费网站| 六月丁香激情综合| 欧美成人一区二免费视频软件| 亚洲精品理论电影| 杨幂一区二区国产精品| 欧美成人app| 欧美日韩在线一区| 蜜臀av性久久久久蜜臀av| 精品av中文字幕在线毛片| 成人夜色视频网站在线观看| 国产精品久久久久久久一区探花| 日本午夜精品理论片a级app发布| 99久久夜色精品国产亚洲1000部| 亚洲女人被黑人巨大进入al| 中文字幕视频观看| 台湾天天综合人成在线| 一本色道久久综合亚洲精品按摩| 国产真实老熟女无套内射| 黄av在线播放| 中文字幕亚洲区| 日韩美女一区| 毛片免费在线观看| 99久久国产综合精品色伊| 成人一区二区三区四区| 99产精品成人啪免费网站| 日本视频一区二区| 国产成人精品综合久久久| 久久99精品波多结衣一区| 欧美精品入口| 久久6免费高清热精品| 蜜桃视频最新网址| 91欧美大片| 中文字幕综合在线| 婷婷丁香综合网| 成人影院天天5g天天爽无毒影院| 亚洲人成自拍网站| 亚洲av无码一区二区三区人 | 黄色片网站在线| 日韩久久一区二区| 中国老女人av| 欧美精品videossex少妇| 亚洲另类色综合网站| 穿情趣内衣被c到高潮视频| 男人的天堂在线视频免费观看| 国产欧美精品国产国产专区| 亚洲欧美日韩精品在线| 黄色片网站在线| 一区二区三区蜜桃网| 激情六月天婷婷| 99在线视频影院| 午夜久久久影院| 日本精品www| 成人在线观看免费播放| 欧美性一二三区| 五月激情五月婷婷| 天堂久久av| 亚洲精品ady| 美国黄色a级片| 久久国产亚洲| 欧美日本高清视频| 国产一区二区99| 青青国产91久久久久久| 91精品在线观| 熟妇人妻系列aⅴ无码专区友真希 熟妇人妻av无码一区二区三区 | 免费在线观看日韩av| 欧美日韩一区二区三区不卡视频| 亚洲欧美在线免费| 一级免费黄色录像| 亚洲视频碰碰| 国产精品视频xxx| 精品人妻aV中文字幕乱码色欲| www.一区二区| 伊人色综合影院| 毛片电影在线| 69精品人人人人| 91视频啊啊啊| 91精品国产福利在线观看麻豆| 久久久久久伊人| 色婷婷久久综合中文久久蜜桃av| 国产福利不卡视频| 日韩成人av网站| 色呦呦在线免费观看| 色噜噜狠狠色综合中国| 波多野结衣在线免费观看| 亚洲激情77| 欧美精品手机在线| 久久精品五月天| 成人精品鲁一区一区二区| 日韩中文字幕一区二区| 俺来也官网欧美久久精品| 欧美色综合久久| 国产人妻人伦精品1国产丝袜| 国产精品久久久久无码av| 欧美孕妇性xx| 国产91久久久| 亚洲欧洲制服丝袜| 欧美一级黄色影院| 精品国产一区二区三区不卡蜜臂| 色偷偷偷亚洲综合网另类| 久久久国产精品成人免费| 国产寡妇亲子伦一区二区| 日韩偷拍一区二区| 中文字幕在线看片| 亚洲第一精品自拍| 中文字幕影音先锋| 美女性感视频久久| 日本黑人久久| 亚洲涩涩在线| 亚洲成年网站在线观看| 黄色a级片在线观看| 丝瓜av网站精品一区二区| 国产高清精品一区二区| 主播国产精品| 欧美一区二区三区电影| 在线观看日本黄色| 日本不卡视频一二三区| 欧美美乳视频网站在线观看| 岛国在线视频网站| 亚洲国产成人久久综合一区| 国产无套粉嫩白浆内谢| 国产超碰在线一区| 黄网站色视频免费观看| 日韩欧洲国产| 欧美日韩成人在线视频| а√天堂资源在线| 亚洲欧美日本韩国| 伊人免费视频二| 国产精品久久久久一区二区三区厕所| 国产精品久久久久久亚洲影视 | 亚洲日本在线看| 午夜福利123| 91精品国产福利在线观看麻豆| 国产在线拍揄自揄视频不卡99 | 成人91在线| 国产精品99久久久久久久久| 狠狠v欧美ⅴ日韩v亚洲v大胸| 欧美三级xxx| 久久久久久久久久久久| 日本欧美在线看| 亚洲一区二区免费视频软件合集| 国产欧美自拍| 蜜臀久久99精品久久久无需会员 | 97成人超碰视| 男人透女人免费视频| 欧美一区电影| 成人黄色在线观看| 曰本三级在线| 日韩av在线导航| 成人免费一区二区三区| 中文字幕一区二区三中文字幕| 亚洲三级在线视频| 亚洲高清激情| 日韩欧美亚洲日产国| 国产一区二区三区国产精品| 久久久久中文字幕2018| 亚洲欧洲精品视频| 欧美性猛片xxxx免费看久爱| 久草视频手机在线| av在线这里只有精品| 丁香婷婷激情网| 中文视频一区| 欧美大香线蕉线伊人久久国产精品 | 亚洲欧美日韩在线| 污污免费在线观看| 视频一区在线播放| 无码人妻精品一区二区三区99v| 999久久久精品一区二区| 秋霞av国产精品一区| 免费在线毛片网站| 亚洲精品按摩视频| 亚洲天堂中文字幕在线| 亚洲小说欧美激情另类| 精品国产成人亚洲午夜福利| 国产综合成人久久大片91| 国产毛片视频网站| 欧美韩日一区| 久99久视频| 国产999精品在线观看| 91精品国产亚洲| 麻豆av免费在线观看| 精品偷拍各种wc美女嘘嘘| 国产乱码精品一区二三区蜜臂| 欧美日韩亚洲一区二| www.毛片com| 久久久久国产精品免费免费搜索| 波多野结衣免费观看| 日韩黄色在线观看| 成人性免费视频| 青青草原综合久久大伊人精品| 国产欧美日本在线| 久久伊人影院| 国产美女久久久| 正在播放日韩精品| 欧美极品少妇全裸体| 欧美日韩xx| 一区二区三区四区在线观看视频| 亚洲乱码在线观看| 一本一道人人妻人人妻αv| 精品成人久久| 自拍偷拍一区二区三区| 久久99国内| 久久久久成人精品免费播放动漫| 欧美视频二区欧美影视| 国产欧美在线视频| 国产亚洲一区二区手机在线观看| 久久全国免费视频| 在线三级中文| 久久亚洲成人精品| 成黄免费在线| 中文字幕视频在线免费欧美日韩综合在线看| 欧美一级特黄aaaaaa大片在线观看| 91精品中文字幕一区二区三区| 中文字幕网址在线| 色综合久久中文综合久久牛| 日韩 欧美 综合| 性感美女极品91精品| 久久免费黄色网址| 夜夜夜精品看看| 99热精品免费| 亚洲夂夂婷婷色拍ww47 | 风流少妇一区二区三区91| 日韩欧美久久一区| av中文字幕第一页| 欧美一级理论性理论a| av观看在线免费| 日韩视频一区在线观看| www.五月激情| 精品国产区一区| 色欲av伊人久久大香线蕉影院| 欧美tickling网站挠脚心| 亚洲精品网站在线| 亚洲成人免费网站| 亚洲欧洲精品视频| 国产婷婷97碰碰久久人人蜜臀 | 日韩人妻精品无码一区二区三区| 亚洲三级国产| 国产乱子夫妻xx黑人xyx真爽| 亚洲欧美视频| 久久婷婷国产91天堂综合精品| 日本午夜精品一区二区三区电影| 亚洲综合日韩欧美| 激情图片小说一区| 丰满人妻一区二区三区53视频| 国产福利精品导航| 国产精品无码在线| 久久精品一区二区三区四区| 你懂得视频在线观看| 亚洲视频网在线直播| 久久无码精品丰满人妻| 大桥未久av一区二区三区| 香蕉污视频在线观看| 欧美日本不卡视频| 亚洲成a人片在线| 亚洲老头同性xxxxx| 天堂аⅴ在线地址8| 欧美老肥婆性猛交视频| 欧美一级鲁丝片| 国产精品九九久久久久久久| 只有精品亚洲| 国产欧美一区二区视频| 欧美日韩国产一区二区三区不卡| 熟妇熟女乱妇乱女网站| 在线精品一区二区| 国产成人手机视频| 国产高清视频一区| 一起草在线视频| 国产午夜亚洲精品午夜鲁丝片| 国产中文av在线| 舔着乳尖日韩一区| 一级黄色大片免费| 亚洲国产日韩一区| 男人天堂手机在线| 欧美亚洲第一区| 国产中文欧美日韩在线| 久久亚洲一区二区| 在线看片不卡| 国产熟女高潮视频| 国产一区二区网址| 蜜桃传媒一区二区亚洲| 一区二区三区免费看视频| 一级黄色在线观看| 精品久久久久av影院| 高清中文字幕一区二区三区| 欧美高清第一页| 国产亚洲精品精品国产亚洲综合| 国产精品香蕉视屏| 五月天综合网站| 无码人妻丰满熟妇区五十路百度| 国产麻豆视频一区二区| 人人人妻人人澡人人爽欧美一区| 一二三区精品福利视频| 96日本xxxxxⅹxxx17| 亚洲美女中文字幕| 电影k8一区二区三区久久| 国产日本欧美视频| 国产成人影院| 国产视频九色蝌蚪| 国产精品一区二区黑丝| 国产精品综合激情| 日韩欧美在线中文字幕| 人妻91麻豆一区二区三区| 美女999久久久精品视频| 91精品影视| 牛人盗摄一区二区三区视频| 亚洲高清二区| 国产xxx在线观看| 亚洲精品免费一二三区| 11024精品一区二区三区日韩| 亚洲乱码国产乱码精品精| 春色校园综合激情亚洲| 国产一区二区三区黄| 国模吧视频一区| 亚洲欧美一区二区三区不卡| 国产精品国产三级国产普通话蜜臀| 国产成人av免费| 在线观看精品自拍私拍| 亚洲人免费短视频| 免费久久99精品国产自| 亚洲欧美日本国产专区一区| 好吊日免费视频| 精品露脸国产偷人在视频| 欧美一级淫片aaaaaa| 久久免费成人精品视频| 盗摄系列偷拍视频精品tp| 欧美无砖专区免费| 成人听书哪个软件好| 日韩大片免费在线观看| 亚洲国产精品久久久久秋霞不卡| 19禁羞羞电影院在线观看| 国产精品区一区二区三在线播放 | 久久久亚洲国产| 影音先锋欧美激情| 男人添女人下部高潮视频在观看 | 最新av电影网站| 制服丝袜亚洲播放| 先锋影音在线资源站91| 国产高清在线一区二区| 99精品99| a级在线免费观看| 欧美日韩成人综合在线一区二区| 日本网站在线免费观看视频| 91亚洲午夜在线| 激情久久综合| 亚洲午夜福利在线观看| 欧美中文字幕久久| 国内外激情在线| 国产精品福利视频| 99视频+国产日韩欧美| 一级黄色性视频| 在线不卡中文字幕| 国产网红在线观看| 欧美日本韩国国产| 精品亚洲欧美一区| 激情综合网五月婷婷| 亚洲女人天堂视频| 97精品资源在线观看| 日韩精品在线中文字幕| 久久久久国产精品麻豆ai换脸| 这里只有精品9| 久久久久久网站| 极品美女一区二区三区| 中文av字幕在线观看| 亚洲成av人片在www色猫咪| 好男人免费精品视频| 亚洲直播在线一区| 久久国产主播| 青青草偷拍视频| 亚洲欧美中文字幕| 精品国产乱码久久久久久樱花| 91猫先生在线| 亚洲欧美区自拍先锋| 欧美理论在线观看| 亚洲free嫩bbb| 日日摸夜夜添夜夜添国产精品| 亚洲成人生活片| 一本色道久久综合亚洲精品小说| 精品国产乱码久久久久久樱花| www.亚洲天堂网| 亚洲一区二区三区在线看|