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

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

升級(jí)到MySQL5.7后開(kāi)發(fā)不得不注意的一些坑

2024-07-25 19:08:38
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

前言

前段時(shí)間,將線上MySQL數(shù)據(jù)庫(kù)升級(jí)到了5.7??紤]到可能產(chǎn)生的不兼容性,在升級(jí)之前,確實(shí)也是戰(zhàn)戰(zhàn)兢兢,雖然測(cè)試環(huán)境,開(kāi)發(fā)環(huán)境早在半年前就已提前升級(jí)。

基于前期的調(diào)研和朋友的反饋,與開(kāi)發(fā)相關(guān)的主要有兩點(diǎn):

sql_mode

MySQL 5.6中,其默認(rèn)值為"NO_ENGINE_SU BSTITUTION",可理解為非嚴(yán)格模式,譬如,對(duì)自增主鍵插入空字符串'',雖然提示warning,但并不影響自增主鍵的生成。

但在MySQL 5.7中,其就調(diào)整為了嚴(yán)格模式,對(duì)于上面這個(gè),其不會(huì)提示warning,而是直接報(bào)錯(cuò)。

分組求最值

分組求最值的某些寫(xiě)法在MySQL5.7中得不到預(yù)期結(jié)果,這點(diǎn),相對(duì)來(lái)說(shuō)比較隱蔽。

其中,第一點(diǎn)是可控的,畢竟可以調(diào)整參數(shù)。而第二點(diǎn),卻是不可控的,沒(méi)有參數(shù)與之相關(guān),需要開(kāi)發(fā)Review代碼。

下面具體來(lái)看看

測(cè)試數(shù)據(jù)

mysql> select * from emp;+-------+----------+--------+--------+| empno | ename | sal | deptno |+-------+----------+--------+--------+| 1001 | emp_1001 | 100.00 | 10 || 1002 | emp_1002 | 200.00 | 10 || 1003 | emp_1003 | 300.00 | 20 || 1004 | emp_1004 | 400.00 | 20 || 1005 | emp_1005 | 500.00 | 30 || 1006 | emp_1006 | 600.00 | 30 |+-------+----------+--------+--------+rows in set (0.00 sec)

其中,empno是員工編號(hào),ename是員工姓名,sal是工資,deptno是員工所在部門(mén)號(hào)。

業(yè)務(wù)的需求是,求出每個(gè)部門(mén)中工資最高的員工的相關(guān)信息。

在MySQL5.6中,我們可以通過(guò)下面這個(gè)SQL來(lái)實(shí)現(xiàn),

SELECT deptno,ename,sal FROM ( SELECT * FROM emp ORDER BY sal DESC ) t GROUP BY deptno;

結(jié)果如下,可以看到,其確實(shí)實(shí)現(xiàn)了預(yù)期效果。

+--------+----------+--------+| deptno | ename | sal |+--------+----------+--------+| 10 | emp_1002 | 200.00 || 20 | emp_1004 | 400.00 || 30 | emp_1006 | 600.00 |+--------+----------+--------+

再來(lái)看看MySQL5.7的結(jié)果,竟然不一樣。

+--------+----------+--------+| deptno | ename | sal |+--------+----------+--------+| 10 | emp_1001 | 100.00 || 20 | emp_1003 | 300.00 || 30 | emp_1005 | 500.00 |+--------+----------+--------+

實(shí)際上,在MySQL5.7中,對(duì)該SQL進(jìn)行了改寫(xiě),改寫(xiě)后的SQL可通過(guò)explain(extended) + show warnings查看。

mysql> explain select deptno,ename,sal from (select * from emp order by sal desc) t group by deptno;+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-----------------+| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra |+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-----------------+| 1 | SIMPLE | emp | NULL | ALL | NULL | NULL | NULL | NULL | 6 | 100.00 | Using temporary |+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-----------------+row in set, 1 warning (0.00 sec)mysql> show warnings/G*************************** 1. row *************************** Level: Note Code: 1003Message: /* select#1 */ select `slowtech`.`emp`.`deptno` AS `deptno`,`slowtech`.`emp`.`ename` AS `ename`,`slowtech`.`emp`.`sal` AS `sal` from `slowtech`.`emp` group by `slowtech`.`emp`.`deptno`row in set (0.00 sec)

從改寫(xiě)后的SQL來(lái)看,其消除了子查詢,導(dǎo)致結(jié)果未能實(shí)現(xiàn)預(yù)期效果,官方也證實(shí)了這一點(diǎn),https://bugs.mysql.com/bug.php?id=80131

 

很多人可能不以為然,認(rèn)為沒(méi)人會(huì)這樣寫(xiě),但在大名鼎鼎的stackoverflow中,該實(shí)現(xiàn)的點(diǎn)贊數(shù)就有116個(gè)-由此可見(jiàn)其受眾之廣,僅次于后面提到的“方法二”(點(diǎn)贊數(shù)206個(gè))。 

https://stackoverflow.com/questions/12102200/get-records-with-max-value-for-each-group-of-grouped-sql-results

需要注意的是,該SQL在5.7中是不能直接運(yùn)行的,其會(huì)提示如下錯(cuò)誤:

ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 't.ename' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by

這個(gè)與sql_mode有關(guān),在MySQL 5.7中,sql_mode調(diào)整為了

ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

其中,ONLY_FULL_GROUP_BY與group by語(yǔ)句有關(guān),其要求select列表里只能出現(xiàn)分組列(即group by后面的列)和聚合函數(shù)(sum,avg,max等),這也是SQL92的標(biāo)準(zhǔn)。

但在工作中,卻經(jīng)??吹介_(kāi)發(fā)寫(xiě)出下面這種SQL。

mysql> select deptno,ename,max(sal) from emp group by deptno;+--------+----------+----------+| deptno | ename | max(sal) |+--------+----------+----------+| 10 | emp_1001 | 200.00 || 20 | emp_1003 | 400.00 || 30 | emp_1005 | 600.00 |+--------+----------+----------+rows in set (0.01 sec)

 實(shí)在不明白,這里的ename在業(yè)務(wù)層有何意義,畢竟,他并不是工資最高的那位員工。 

分組求最值,MySQL的實(shí)現(xiàn)方式

其實(shí)分組求最值是一個(gè)很普遍的需求。在工作中,也經(jīng)常被開(kāi)發(fā)同事問(wèn)到。 下面具體來(lái)看看,MySQL中有哪些實(shí)現(xiàn)方式。

方法1

SELECT e.deptno, ename, sal FROM emp e, ( SELECT deptno, max( sal ) maxsal FROM emp GROUP BY deptno ) t WHERE e.deptno = t.deptno  AND e.sal = t.maxsal;

方法2

SELECT a.deptno, a.ename, a.sal FROM emp a LEFT JOIN emp b ON a.deptno = b.deptno  AND a.sal < b.sal WHERE b.sal IS NULL;

這兩種實(shí)現(xiàn)方式,其實(shí)是通用的,不僅適用于MySQL,也適用于其它主流關(guān)系型數(shù)據(jù)庫(kù)。

方法3

MySQL 8.0推出了分析函數(shù),其也可實(shí)現(xiàn)類似功能。

SELECT deptno, ename, sal FROM ( SELECT deptno, ename, sal, LAST_VALUE ( sal ) OVER ( PARTITION BY deptno ORDER BY sal ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING ) maxsal  FROM emp  ) a WHERE sal = maxsal;

三種實(shí)現(xiàn)方式的性能對(duì)比

因上面測(cè)試案例的數(shù)據(jù)量太小,三種實(shí)現(xiàn)方式的結(jié)果都是秒出,僅憑執(zhí)行計(jì)劃很難直觀地看出實(shí)現(xiàn)方式的優(yōu)劣。

下面換上數(shù)據(jù)量更大的測(cè)試數(shù)據(jù),官方示例數(shù)據(jù)庫(kù)employees中的dept_emp表,https://github.com/datacharmer/test_db

表的相關(guān)信息如下,其中emp_no是員工編號(hào),dept_no是部門(mén)編號(hào),from_date是入職日期。

mysql> show create table dept_emp/G*************************** 1. row *************************** Table: dept_empCreate Table: CREATE TABLE `dept_emp` ( `emp_no` int(11) NOT NULL, `dept_no` char(4) NOT NULL, `from_date` date NOT NULL, `to_date` date NOT NULL, KEY `dept_no` (`dept_no`,`from_date`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_cirow in set (0.00 sec)mysql> select count(*) from dept_emp;+----------+| count(*) |+----------+| 331603 |+----------+row in set (0.09 sec)mysql> select * from dept_emp limit 1;+--------+---------+------------+------------+| emp_no | dept_no | from_date | to_date |+--------+---------+------------+------------+| 10001 | d005 | 1986-06-26 | 9999-01-01 |+--------+---------+------------+------------+row in set (0.00 sec)

方法1

mysql> select d.dept_no,d.emp_no,d.from_date from dept_emp d, (select dept_no,max(from_date) max_hiredate from dept_emp group by dept_no) t where d.dept_no=t.dept_no and d.from_date=t.max_hiredate;…rows in set (0.00 sec)mysql> explain select d.dept_no,d.emp_no,d.from_date from dept_emp d, (select dept_no,max(from_date) max_hiredate from dept_emp group by dept_no) t where d.dept_no=t.dept_no and d.from_date=t.max_hiredate;+----+-------------+------------+------------+-------+---------------+---------+---------+--------------------------+------+----------+----------------------| id | select_type | table | partitions | type | possible_keys | key | key_len | ref   | rows | filtered | Extra  +----+-------------+------------+------------+-------+---------------+---------+---------+--------------------------+------+----------+----------------------| 1 | PRIMARY | <derived2> | NULL | ALL | NULL  | NULL | NULL | NULL   | 9 | 100.00 | Using where  | 1 | PRIMARY | d  | NULL | ref | dept_no | dept_no | 19 | t.dept_no,t.max_hiredate | 5 | 100.00 | NULL   | 2 | DERIVED | dept_emp | NULL | range | dept_no | dept_no | 16 | NULL   | 9 | 100.00 | Using index for group-by+----+-------------+------------+------------+-------+---------------+---------+---------+--------------------------+------+----------+----------------------

方法2

mysql> explain select a.dept_no,a.emp_no,a.from_date from dept_emp a left join dept_emp b on a.dept_no=b.dept_no and a.from_date < b.from_date where b.from_date is null;+----+-------------+-------+------------+------+---------------+---------+---------+--------------------+--------+----------+--------------------------+| id | select_type | table | partitions | type | possible_keys | key | key_len | ref  | rows | filtered | Extra   |+----+-------------+-------+------------+------+---------------+---------+---------+--------------------+--------+----------+--------------------------+| 1 | SIMPLE | a | NULL | ALL | NULL  | NULL | NULL | NULL  | 331008 | 100.00 | NULL   || 1 | SIMPLE | b | NULL | ref | dept_no | dept_no | 16 | slowtech.a.dept_no | 41376 | 19.00 | Using where; Using index |+----+-------------+-------+------------+------+---------------+---------+---------+--------------------+--------+----------+--------------------------+rows in set, 1 warning (0.00 sec)

方法3

mysql> select dept_no,emp_no,from_date from ( select dept_no,emp_no,from_date,last_value(from_date) over(partition by dept_no order by from_date rows between unbounded preceding and unbounded following) max_hiredate from dept_emp) a where from_date=max_hiredate;…rows in set (1.57 sec)mysql> desc select dept_no,emp_no,from_date from ( select dept_no,emp_no,from_date,last_value(from_date) over(partition by dept_no order by from_date rows between unbounded preceding and unbounded following) max_hiredate from dept_emp) a where from_date=max_hiredate;+----+-------------+------------+------------+------+---------------+------+---------+------+--------+----------+----------------+| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra  |+----+-------------+------------+------------+------+---------------+------+---------+------+--------+----------+----------------+| 1 | PRIMARY | <derived2> | NULL | ALL | NULL  | NULL | NULL | NULL | 331008 | 100.00 | Using where || 2 | DERIVED | dept_emp | NULL | ALL | NULL  | NULL | NULL | NULL | 331008 | 100.00 | Using filesort |+----+-------------+------------+------------+------+---------------+------+---------+------+--------+----------+----------------+rows in set, 2 warnings (0.00 sec)

從執(zhí)行時(shí)間上看,

方法1的時(shí)間最短,在有復(fù)合索引(deptno, fromdate)的情況下,結(jié)果瞬間就出來(lái)了,即使在沒(méi)有索引的情況下,也只消耗了0.75s。

方法2的時(shí)間最長(zhǎng),3個(gè)小時(shí)還是沒(méi)出結(jié)果。同樣的數(shù)據(jù),同樣的SQL,放到Oracle查,也消耗了87分49秒。

方法3的時(shí)間比較固定,無(wú)論是否存在索引,都維持在1.5s左右,比方法1的耗時(shí)要久。

這里,對(duì)之前提到的,MySQL 5.7中不再兼容的實(shí)現(xiàn)方式也做了個(gè)測(cè)試,在沒(méi)有任何索引的情況下,其穩(wěn)定在0.7s(性能并不弱,怪不得有人使用),而同等情況下,方法1穩(wěn)定在0.5s(哈,MySQL 5.6竟然比8.0還快)。但與方法1不同的是,其無(wú)法通過(guò)索引進(jìn)行優(yōu)化。

從執(zhí)行計(jì)劃上看,

方法1, 先將group by的結(jié)果放到臨時(shí)表中,然后再將該臨時(shí)表作為驅(qū)動(dòng)表,來(lái)和dept_emp表進(jìn)行關(guān)聯(lián)查詢。驅(qū)動(dòng)表小(只有9條記錄),關(guān)聯(lián)列又有索引,無(wú)怪乎,結(jié)果能秒出。

方法2, 兩表關(guān)聯(lián)。其犯了SQL優(yōu)化中的兩個(gè)大忌。

   1. 驅(qū)動(dòng)表太大,其有331603條記錄。

   2. 被驅(qū)動(dòng)表雖然也有索引,但從執(zhí)行計(jì)劃上看,其只使用了復(fù)合索引  (dept_no, from_date)中的dept_no,而dept_no的選擇率又太低,畢竟只有9個(gè)部門(mén)。

方法3, 先把分析的結(jié)果放到一個(gè)臨時(shí)表中,然后再對(duì)該臨時(shí)表進(jìn)行處理。其進(jìn)行了兩次全表掃描,一次是針對(duì)dept_emp表,一次是針對(duì)臨時(shí)表。

所以,對(duì)于分組求最值的需求,建議使用方法1,其不僅符合SQL規(guī)范,查詢性能上也是最好的,尤其是在聯(lián)合索引的情況下。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)VeVb武林網(wǎng)的支持。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
www.成人爱| 一区二区三区中文| 亚洲精品国产一区二区三区| 欧美黄色成人网| 91精品大全| 久久久久久国产精品mv| 三级黄色在线视频| 波多野结衣视频播放| 国产+高潮+白浆+无码| 污视频在线看操| 成人看片黄a免费看在线| 亚洲大尺度美女在线| 黄色片一区二区三区| 一区二区乱子伦在线播放| 精品99久久久久成人网站免费| 4438欧美| 欧美专区第二页| www.1024| 亚洲精品aⅴ中文字幕乱码| 男人av在线| 国产综合成人久久大片91| 在线看国产视频| 午夜精品美女久久久久av福利| 亚洲久本草在线中文字幕| 午夜视频一区在线观看| 黄色片在线观看网站| 欧美一级二级三级九九九| 免费黄色影片在线| 欧美人与z0zoxxxx视频| 一二三区在线| 亚洲精品免费播放| 国产在线视频你懂得| 精品无码久久久久久久久| 亚洲欧美欧美一区二区三区| 欧美性色综合| 一级二级黄色片| 欧美伊久线香蕉线新在线| 欧州一区二区| 污网站免费在线观看| 在线视频一区二区三区在线播放| 毛片基地黄久久久久久天堂| www.色视频| 亚洲老头老太hd| 久久久久久久久久久人体| 成人xvideos免费视频| 无码国产精品一区二区免费16| 免费久久网站| 国产女主播一区| 一区二区三区四区在线看| freemovies性欧美| 99久久免费精品国产72精品九九| 另类的小说在线视频另类成人小视频在线| 国产一二在线观看| 国产亚洲成av人片在线观看| 亚洲成人av资源| 国产精品一区二区三| 免费看日本一区二区| 理论片大全免费理伦片| 国产又粗又黄又爽的视频| 传媒av在线| 国产午夜免费视频| 蜜桃a∨噜噜一区二区三区| 18岁成年人网站| 日韩和欧美一区二区三区| 91精品视频在线播放| 在线免费观看h视频| 亚洲成人套图| 亚洲熟妇无码av在线播放| 一区二区在线免费看| 国产91aaa| 中文字幕午夜精品一区二区三区| 91免费视频网站在线观看| 亚洲精品美腿丝袜| 亚洲午夜无码av毛片久久| 色哟哟入口国产精品| 免费黄色在线| 精品欧美一区二区久久久久| 国内偷自视频区视频综合| 国产精品三区www17con| 亚州一区二区三区| 成人久久18免费网站麻豆| 亚洲午夜精品网| 菠萝蜜视频国产在线播放| 久久精品国产一区| 四虎精品一区二区免费| 国产精品毛片久久久久久久av| 久久发布国产伦子伦精品| 色婷婷久久久亚洲一区二区三区| 日韩欧美激情四射| 日本一本在线免费福利| 亚洲午夜久久久久久久| 久久精品青青大伊人av| 91精品国产自产在线观看永久| 男女午夜视频在线观看| av成人观看| 中文字幕日韩一区二区| t66y最新发布地址| 特黄aaaaaaaaa毛片免费视频| 久久精品一区二区三区不卡牛牛| 国产精品福利电影| 久久久久久av无码免费网站| 黄网视频在线观看| 日韩不卡手机在线v区| 亚洲一区视频在线观看视频| 国产美女主播视频一区| 永久免费无码av网站在线观看| 欧美理伦片在线播放| 亚洲综合五月天婷婷丁香| 亚洲欧美日韩第一区| 99这里只有久久精品视频| 视频一区视频二区国产精品| 国产又粗又长又大视频| 欧洲美女日日| 欧美 日韩 国产 精品| 久久国产尿小便嘘嘘| 免费观看美女裸体网站| 国产精品久久激情| 成年人网站大全| 国产日产欧美一区二区三区| 成年人性生活视频| 高清无码一区二区在线观看吞精| 国模无码国产精品视频| 香蕉视频污视频| 亚洲精品国产偷自在线观看| 欧美成va人片在线观看| 国产精品一区二区你懂得| 国产精品视频自在线| 国产成人精品电影| 国产剧情一区二区三区| www.中文字幕在线观看| 韩国日本不卡在线| 看全色黄大色黄大片免责看的| 一区二区视频在线播放| 在线免费观看一区二区三区| 国产模特精品视频久久久久| 岛国精品在线观看| 三级黄色片免费观看| 91欧美在线视频| 亚洲第一页综合| 成人免费毛片视频| 国产日韩欧美黄色| 成人无码精品1区2区3区免费看| 91精品999| 在线一区二区日韩| 久热中文字幕在线观看| 日本少妇做爰全过程毛片| 午夜影视日本亚洲欧洲精品| 美女一区二区三区视频| 色综合久久精品| 一区二区免费在线观看| 欧美亚洲福利| 国产三级黄色片| 欧美尤物巨大精品爽| 久久人妻精品白浆国产| 亚洲精品成人天堂一二三| 91老司机福利在线| 中文字幕欧美人妻精品一区蜜臀| 天堂а√在线最新版中文在线| 99热在这里有精品免费| 强伦人妻一区二区三区| 亚洲一区 二区 三区| 国产亚洲第一伦理第一区| 91精品中文在线| 成人毛片网站| 亚洲欧美中文日韩在线v日本| 国产成人免费看一级大黄| 99riav一区二区三区| 国产精品免费福利| 色与欲影视天天看综合网| 欧美91在线|欧美| 国产精品91av| 国产激情无码一区二区三区| 91免费福利视频| 国产黄色一级大片| 蜜桃视频在线观看播放| 国产女主播在线播放| 亚洲精品在线免费播放| 少妇高清精品毛片在线视频| 日韩激情av| 国产精品一区二区三区在线| 97香蕉久久夜色精品国产| 16—17女人毛片毛片| 久久发布国产伦子伦精品| 美女视频黄是免费| 91精品国产高清久久久久久久久| 黄页网站大全一区二区| 国产真人做爰视频免费| 国产aⅴ综合色| 91av视频在线免费观看| 草草影院在线观看| 欧美福利网站| 少妇高潮久久久久久潘金莲| 一本大道久久加勒比香蕉| а√最新版地址在线天堂| 日韩一区二区在线视频| 捆绑变态av一区二区三区| 在线亚洲精品| 在线 丝袜 欧美 日韩 制服| 97人人做人人爽香蕉精品| 美女久久久久久| 欧美综合一区二区| 日韩大陆毛片av| 蜜桃久久久久久| 国产精品入口久久| 午夜欧美精品久久久久久久| 99在线看视频| 精品国产亚洲一区二区在线观看| 亚洲成人在线视频网站| 精品美女久久久久久免费| 亚洲国产天堂久久国产91| 伊人网在线播放| 欧美日韩国产色综合一二三四| 精品在线视频免费观看| av片在线观看永久免费| 国产精品无码永久免费888| 欧美日韩国产v| 国产精品久久成人免费观看| 国产精品xxxxxx| 国户精品久久久久久久久久久不卡| 国产一区二区在线电影| 亚洲成人777| 国产乱人乱偷精品视频a人人澡| 麻豆传媒视频在线| 亚洲 欧美 精品| 中文字幕第69页| 2023亚洲男人天堂| 国产风韵犹存在线视精品| 免费污视频在线| 日日夜夜一区二区| 国产一级片一区二区| 91传媒视频在线观看| 国产三级按摩推拿按摩| 成人资源www网在线最新版| 久久久久av| 欧美精品18videos性欧| 国产精品久久久久无码av色戒| 18aaaa精品欧美大片h| 免费电影网站在线视频观看福利| 狠狠色丁香久久综合频道| 国产精品色婷婷| 久久久精品免费免费| aa日韩免费精品视频一| 日韩中文有码在线视频| 国产婷婷色一区二区三区在线| 国产欧美一区二区三区在线看蜜臂| 亚洲三级中文字幕| 亚洲国产成人精品女人久久久| 亚洲国产精品无码久久久久高潮| 午夜美女福利视频| 欧美一级大片在线视频| 8x8x8国产精品| 最新国产在线观看| 欧美日韩国产成人在线| 韩国成人动漫| 欧美成人影院在线播放| 亚洲国产成人私人影院| 亚洲一区在线观看免费观看电影高清| 综合蜜桃精品| 欧美成年人网站| 精品无吗乱吗av国产爱色| 欧美一级一区二区三区| 成人网在线免费观看| 不卡视频在线看| 国产精品一区一区三区| 7777精品伊久久久大香线蕉语言| 欧洲毛片在线视频免费观看| av一本久道久久综合久久鬼色| 日本美女一级片| 国产精品久久久久9999赢消| 波多野结衣亚洲一区| 天天躁日日躁狠狠躁欧美巨大小说| 国产成人短视频在线观看| 亚州国产精品久久久| 91中文字精品一区二区| 国产精品一香蕉国产线看观看| 午夜精品一区在线观看| 色呦呦在线观看视频| 欧美二区观看| 日本1级在线| 天堂入口网站| 91亚洲精品久久久久久久久久久久| www.欧美免费| 国产日韩精品一区二区浪潮av| 欧美久久久网站| 青青草视频在线青草免费观看| 日韩av片免费在线观看| 亚洲自拍另类欧美丝袜| 中文字幕在线日本| 国产黄色片免费看| 国产丝袜一区二区| 日韩av一区二区在线影视| 欧美在线free| 欧美日产国产成人免费图片| 一级毛片视频在线观看| 国产二区三区在线| 神马久久精品综合| 自拍偷拍亚洲视频| 国产女无套免费视频| 欧美丰满高潮xxxx喷水动漫| 麻豆国产欧美一区二区三区r| 国产毛片一区二区| 美女福利视频一区| 亚洲福利在线观看| av播放在线观看| 天堂精品高清1区2区3区| 欧美日韩国产精品一区二区三区四区| 成人黄色短视频在线观看| 久久精品亚洲成在人线av网址| 免费人成黄页在线观看忧物| 免费一级欧美在线观看视频| 91麻豆精品国产自产在线观看一区| 亚洲人成精品久久久久| 欧美大胆的人体xxxx| 成人网在线播放| 99热在线网站| 综合一区av| 欧美一区二区三区影院| 亚洲影院高清在线| 操人视频欧美| 欧美伦理91i| 男人操女人的视频在线观看欧美| 制服丝袜中文字幕在线观看| 免费一级suv好看的国产网站| 综合伊思人在钱三区| 亚洲精品国产一区二| 国产情人综合久久777777| 丝袜亚洲另类欧美| 另类图片国产|