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

幻讀為什么會被 MySQL 單獨拎出來解決?

數據庫 MySQL
所謂幻讀,即一個事務在前后兩次查詢同一個范圍的時候,后一次查詢看到了前一次查詢沒有看到的行,這個回答估計大伙兒已經背爛了,但是它具體有什么后果呢?

[[437528]]

本文轉載自微信公眾號「飛天小牛肉」,作者飛天小牛肉 。轉載本文請聯系飛天小牛肉公眾號。

所謂幻讀,即一個事務在前后兩次查詢同一個范圍的時候,后一次查詢看到了前一次查詢沒有看到的行,這個回答估計大伙兒已經背爛了,但是它具體有什么后果呢?為什么會被 MySQL 單獨拎出來解決呢?MySQL 又是如何解決的呢?

當前讀和快照讀

在了解幻讀以及 MySQL 是如何解決幻讀這個問題前,我們需要知道,什么是當前讀、什么是快照讀。

  • 快照讀:讀取快照中的數據,不需要進行加鎖。看到快照這兩個字,各位肯定馬上就想到 MVCC 了,是這樣,MVCC 作用于讀取已提交和可重復讀(默認)這兩個隔離級別,這倆隔離級別下的普通 select 操作就是快照讀
  • 當前讀:讀取的是最新版本的數據, 并且對讀取的記錄加鎖, 阻塞其他事務同時改動相同記錄,避免出現安全問題。

除了讀取已提交和可重復讀這倆隔離級別下的普通 select 操作,其余操作都是當前讀:

  1. select...lock in share mode (共享讀鎖) 
  2. select...for update 
  3. updatedeleteinsert 

舉個例子,來直觀感受下快照讀和當前讀,以可重復讀隔離級別為例,假設我們目前有一張 user 表,有如下的數據:

開啟兩個事務:

事務 1 先來個快照讀看看:

沒毛病,很正常。

事務 2 修改 age = 99,然后提交:

你猜,這時候,事務 1 快照讀出來的數據應該是多少?

是的,仍然是舊數據:

那事務 1 “當前讀” 出來的數據肯定是最新的了:

幻讀到底有什么問題

所謂幻讀,即一個事務在前后兩次查詢同一個范圍的時候,后一次查詢看到了前一次查詢沒有看到的行。

在可重復讀隔離級別下,普通的查詢是快照讀,當前事務是不會看到別的事務插入的數據的。因此,幻讀問題在 “當前讀” 下才會出現。

也有很多的文章說用 MVCC 來解決 "快照讀" 下的幻讀問題,我覺得沒必要糾結吧,甚至可能面試官更可能愿意聽到 MVCC 的原理。

不過,話說回來,沒有 MVCC 機制,哪來快照讀這個東西?

那么,幻讀到底有什么問題?它具體有什么后果呢?

不多廢話,直接上例子:

我們有一張表 user(id, username, age),已經有兩條數據 (1, "Jack", 20), (2, "Tom", 18)

有如下三個事務:

眾所周知,select for update 語句會加行鎖,假設,注意這里是假設奧!!!假設事務 1 的 select * from user where name = 'Jack' for update 只在 id = 1 的這一行上加行鎖

可以看到,事務 1 執行了三次查詢,都是要查出 name = "Jack" 的記錄行。注意我們假設這里只在 name = 'Jack' 行上加行鎖

  • 第一次查詢只返回了 id = 1 這一行
  • 在第二次查詢之前,事務 2 把 id = 2 這一行的 name 值改成了 "Jack",因此事務 1 第二次查詢的結果是 id = 1 和 id = 2 這兩行
  • 在第三次查詢之前,事務 3 插入了一個 name = "Jack" 的新數據,因此事務 1 第三次查詢的結果是 id = 1、id = 2 以及 id = 3 這三行

顯然,第三次查詢讀到的 id = 3 這一行的現象,就是幻讀

但其實從邏輯上來說,這似乎是沒有問題的。

因為這三個查詢都是加了 for update,都是當前讀。而當前讀的規則,就是要能讀到所有已經提交的記錄的最新值,所以第二次查詢和第三次查詢就是應該看到事務 2 和事務 3 的操作效果。

那么,幻讀到底有啥問題?

首先是語義上的。事務 1 在第一次查詢的時候就聲明了,我要把所有 name = "Jack" 的行鎖住,拒絕別的事務對 name = "Jack" 的行進行讀寫操作。

但是,實際上,這個語義被破壞了,舉個例子,我再往事務 2 里加一條 SQL 語句(黃色框框):

事務 2 的第二條語句的意思是 "把 id = 2 這一行的 age 值改成了 40",這行的 name 值是 "Jack"。

而在這之前,事務 1 只是給 id = 5 的這一行加了行鎖,并沒有給 id = 2 這行加鎖。所以,事務 2 是可以執行這條 update 語句的。

這樣,事務 2 先將 id = 2 的 name 改為 Jack,然后再將 age 改為 40,破壞了事務 1 對要把所有 "name = Jack 的行鎖住" 的聲明

其次,最重要的是,是數據一致性的問題。

眾所周知,加鎖是為了保證數據的一致性,這個一致性,不僅包括數據的一致性,還包括數據和日志的一致性,舉個例子:

給事務 1 再加上一條 SQL 語句(黃色框框)

我在上圖中圈出了四個時刻, T1 T2 T3 和 T4,我們來分析下經過這四個時刻的數據庫狀態:

  • 經過 T1 時刻,id = 1 這一行變成 (1, Tom, 20),注意這是在 T4 才正式提交的
  • 經過 T2 時刻,id = 2 這一行變成 (2, Jack, 40)
  • 經過 T3 時刻,表里面多了一行 (3, Jack, 30)

再來看看這時候 binlog 日志里面的內容,binlog 就是記錄下我們做了哪些操作嘛:

T2 時刻,事務 2 提交,寫入了 2 條 update 語句;

  1. update user set name = "Jack" where id = 2 
  2. update user set age = "40" where id = 2 /*(2, Jack, 40)*/ 

T3 時刻,事務 3 提交,寫入了 1 條語句; 

  1. insert into user values(3, "Jack", 30) /*(3, Jack, 30)*/ 

T4 時刻,事務 1 提交,binlog 中寫入了 update user set name = "Tom" where name = "Jack" 這條語句

  1. update user set name = "Tom" where name = "Jack" 

就是說,把所有 name = Jack 的行,都給我改成 name = "Tom"

這樣,問題就來嘍,binlog 一般都是用于備庫同步主庫的對吧,這個 binlog 一執行,那豈不是原先 (2, Jack, 40) 和 (3, Jack, 30) 這兩行的 name 全都變成了 Tom。

也就是說,id = 2 和 id = 3 這兩行,發生了數據不一致。

注意!這個數據不一致到底是怎么發生的?是假設事務 1 的 select * from user where name = 'Jack' for update 只在 id = 1 的這一行上加行鎖導致的。

很顯然,分析到這里,我們已經明白,只鎖這一行是不合理的。那好辦,讓 select for update 把所有掃描到的行都給鎖住不就行了?

這樣,事務 2 在 T2 時刻就會被阻塞住,直到事務 1 在 T4 時刻 commit 釋放鎖。

由于 session A 把所有的行都加了寫鎖,所以 session B 在執行第一個 update 語句的時候就被鎖住了。需要等到 T6 時刻 session A 提交以后,session B 才能繼續執行。

But,這樣看似沒問題,是否真的沒問題呢?

來看 binlog,執行序列是這樣的:

  1. 事務 3: 
  2. insert into user values(3, "Jack", 30) /*(3, Jack, 30)*/ 
  3.  
  4. 事務 1: 
  5. update user set name = "Tom" where name = "Jack" 
  6.  
  7. 事務 2: 
  8. update user set name = "Jack" where id = 2 
  9. update user set age = "40" where id = 2 /*(2, Jack, 40)*/ 

可以看到,事務 2 的問題確實是解決了,Jack 保住了,仍然是 (2, Jack, 40)

但是!!!注意事務 3,在數據庫里面的結果是 (3, "Jack", 30),而根據 binlog 的執行結果是 (3, Tom, 30),也就是說幻讀的問題還是沒有解決。

那為什么我們已經把所有能夠掃描到的記錄都加上了鎖,還是阻止不了 id = 3 這一行的插入和更新呢?

很簡單。在我們給所有行加鎖的時候,id = 3 這一行還不存在,數據庫掃描不到,也就當然加不上鎖了。

這也是為什么幻讀問題會被單獨拿出來解決的原因,即使我們把所有的的記錄都加上鎖,還是阻止不了新插入的記錄。

MySQL 如何解決幻讀

現在你知道了,產生幻讀的原因是,行鎖只能鎖住行,但是新插入記錄這個動作,操作的是鎖住的行之間的 “間隙”。因此,為了解決幻讀問題,InnoDB 只好引入新的鎖,也就是間隙鎖 (Gap Lock)。

這樣,當你執行 select * from user where name = 'Jack' for update 的時候,就不止是給數據庫中已有的 n 個記錄加上了行鎖,還同時加了 n + 1 個間隙鎖(這兩個合起來也成為 Next-Key Lock 臨鍵鎖)。也就是說,在數據庫一行行掃描的過程中,不僅掃描到的行加上了行鎖,還給行兩邊的空隙也加上了鎖。這樣就確保了無法再插入新的記錄。

這里多提一嘴,update、delete 語句用不上索引是很恐怖的。

對非索引字段進行 select .. for update、update 或者 delete 操作,由于沒有索引,走全表查詢,就會對所有行記錄 以及 所有間隔 都進行上鎖。而對于索引字段進行上述操作,只有索引字段本身和附近的間隔會被加鎖。

總結下 MySQL 解決幻讀的手段:

隔離級別:可重復讀

  • 快照讀 MVCC + 當前讀 Next-Lock Key(只在可重復讀隔離級別下生效)

隔離級別:SERIALIZABLE

  • 在這個隔離級別下,事務在讀操作時,先加表級別的共享鎖,直到事務結束才釋放;事務在寫操作時,先加表級別的排它鎖,直到事務結束才釋放。也就是說,串行化鎖定了整張表,幻讀不存在的

最后放上這道題的背誦版:

面試官:幻讀有什么問題,MySQL 是如何解決幻讀的

小牛肉:幻讀就是一個事務在前后兩次查詢同一個范圍的時候,后一次查詢看到了前一次查詢沒有看到的行。

幻讀的后果就是數據庫中的數據和 binlog 的執行結果會不一致,其原因就在于,我們無法阻止新插入的數據。就是說,我們在給掃描到的行加鎖的時候,你等會要插入的行還不存在,也就沒法對他進行加鎖,那么這個新插入的數據,可能在主庫中是這個樣子,從庫執行完 binlog 后其實是會被修改的。

這也就是為啥幻讀會被單獨拎出來解決的原因了。

幻讀問題在 "當前讀" 下才會出現。

所謂當前讀就是,讀取的是最新版本的數據, 并且對讀取的記錄加鎖, 阻塞其他事務同時改動相同記錄,避免出現安全問題。

與之對應的,快照讀,讀取的是快照中的數據,不需要進行加鎖。讀取已提交和可重復讀這倆隔離級別下的普通 select 操作就是快照讀。其實就是 MVCC 機制,或者說,在快照讀下,采用 MVCC 機制解決幻讀。

然后,對于當前讀這種情況,前面我們說,由于無法阻止新插入的數據,所以無法解決幻讀問題,所以,我們考慮,不僅對掃描到的行進行加鎖,還對行之間的間隙進行加鎖,這樣就能杜絕新數據的插入和更新。這個其實就是記錄鎖 Record Lock 和間隙鎖 Gap Lock,也被稱為臨鍵鎖 Next-Lock Key。

 額臨鍵鎖只在可重復讀也就是 InnoDB 的默認隔離級別下生效。也可以采用更高的可串行化隔離級別,所有的操作都是串行執行的,可以直接杜絕幻讀問題。

 

責任編輯:武曉燕 來源: 飛天小牛肉
相關推薦

2022-06-30 08:00:00

MySQL關系數據庫開發

2023-08-09 17:22:30

MVCCMySQL數據

2019-05-28 13:50:27

MySQL幻讀數據庫

2024-04-19 08:18:47

MySQLSQL隔離

2023-06-05 00:28:24

MySQL數據庫非鎖定讀

2024-09-02 00:00:00

MySQL幻讀數據

2024-05-13 11:46:33

MySQL數據庫

2020-01-13 10:16:53

TCPUDP協議

2020-04-01 15:30:19

TCPUDP服務器

2020-01-15 08:42:16

TCP三次握手弱網絡

2018-03-13 09:34:36

Kubernetes容器系統

2012-05-22 00:25:41

.NET

2021-10-13 06:49:15

網絡 IO

2024-04-24 08:26:35

事務數據InnoDB

2021-04-20 19:21:50

臟讀MySQL幻讀

2019-12-24 14:50:01

MySQL可重復讀數據庫

2010-11-09 10:36:39

求職

2021-02-11 13:30:56

Nodejs源碼c++

2024-04-25 08:16:06

InnodbReadMVCC

2020-07-06 14:16:22

Fastjson漏洞開源
點贊
收藏

51CTO技術棧公眾號

激情成人开心网| 肥熟一91porny丨九色丨| the porn av| 欧美a免费在线| 高清在线成人网| 欧美一区二区色| 久久精品一区二区三区四区五区| 国产精品亚洲一区二区三区在线观看| 丁香六月久久综合狠狠色| 97色在线播放视频| 国产3级在线观看| 欧美巨大xxxx| 欧美日韩一区二区免费在线观看 | 国产一区二区三区朝在线观看| 99视频在线精品| 97久久伊人激情网| 男人在线观看视频| 91麻豆精品国产综合久久久 | 亚洲一区二区三区乱码 | 一区二区影院| 亚洲图片欧美午夜| xxxxwww一片| 成人精品一区二区三区电影| 午夜在线电影亚洲一区| 一区精品在线| 国产福利在线| 91色porny在线视频| 亚洲综合一区二区不卡| 亚洲第一区av| 亚洲欧美视频| 日韩中文理论片| 一级 黄 色 片一| 国产一区一一区高清不卡| 亚洲午夜av在线| 18视频在线观看娇喘| porn视频在线观看| 久久综合精品国产一区二区三区| 日本一区二区不卡| 日本三级2019| 红桃视频国产精品| 九九九久久国产免费| 日本 欧美 国产| 久久精品av| 深夜福利亚洲导航| 亚洲av无码国产精品麻豆天美| 4438五月综合| 亚洲6080在线| 美脚丝袜脚交一区二区| 久草在线视频网站| 一区二区高清视频在线观看| 熟女熟妇伦久久影院毛片一区二区| 免费看av毛片| 成人精品一区二区三区四区 | 麻豆传媒一区二区| 六月丁香色婷婷| 成人精品一区二区三区四区| 99国产在线观看| 朝桐光av在线一区二区三区| 国产精品一区免费在线观看| 成人免费在线视频网站| 天天爽夜夜爽夜夜爽精品| 亚洲激情另类| 91国产美女视频| 国产黄色免费观看| 天堂成人免费av电影一区| 久久综合九色九九| 欧美成人精品欧美一| 欧美日本三区| 91精品国产91久久| 午夜精品久久久久久久蜜桃| 日一区二区三区| 国产欧美日韩精品丝袜高跟鞋| 1级黄色大片儿| 亚洲色图插插| 国内精品久久影院| 在线免费观看av网址| 日本大胆欧美人术艺术动态| 国产欧美最新羞羞视频在线观看| 午夜精品久久久久久久久久久久久蜜桃| 水蜜桃久久夜色精品一区| 日韩小视频在线观看| 福利所第一导航| 午夜影院欧美| 中文字幕视频在线免费欧美日韩综合在线看 | 成人黄视频在线观看| 亚洲观看高清完整版在线观看| 亚洲一区二区精品在线| 尤物视频在线看| 亚洲免费av网站| 免费成人午夜视频| 亚洲爱爱视频| 精品日韩av一区二区| 人人妻人人澡人人爽人人精品| 国内视频在线精品| 中文字幕欧美国内| 国产精品美女高潮无套| 伊人久久大香线蕉| 日韩视频第一页| aaa人片在线| 久久国产精品99精品国产| 国产伦精品一区二区三区高清| 精品黑人一区二区三区在线观看| 精品一区二区日韩| 国产伦精品一区二区三区免| 国产午夜视频在线观看| 一区二区三区不卡在线观看 | 永久免费黄色片| 国产精品日韩精品在线播放| 日韩电影中文字幕| 一本色道综合久久欧美日韩精品 | 免费高清在线一区| 国产在线精品一区| 午夜激情视频在线| 色综合久久88色综合天天6| 永久看看免费大片| 中文字幕亚洲在线观看| 精品精品欲导航| 国产精品成人99一区无码| 色婷婷亚洲mv天堂mv在影片| 高清欧美性猛交xxxx| 波多野结衣国产| 国产精品一区一区三区| 亚洲图片小说在线| 黑人巨大精品| 欧美精品成人一区二区三区四区| 波多野结衣电影免费观看| 国内精品伊人久久久| 97在线观看视频| 中文天堂在线视频| 久久亚洲综合色| 91九色在线观看视频| 日韩中文字幕无砖| 久久国产精品久久国产精品| 性高潮视频在线观看| 91影院在线观看| 亚洲熟妇无码一区二区三区| 波多野结衣亚洲| 亚洲成人久久网| 国产一级理论片| 国产乱子伦视频一区二区三区| 国产午夜精品一区| 七七久久电影网| 精品国产成人系列| 国产又粗又猛又爽又黄的视频四季| 亚洲高清资源在线观看| 国产精品永久免费在线| 亚洲精品无遮挡| 一区二区三区在线观看欧美| 中文字幕色网站| 欧美成人直播| 成人网在线视频| 国产美女在线观看| 欧美一区二区三区在线| 午夜少妇久久久久久久久| 狠狠色综合播放一区二区| 一区二区三区四区视频在线观看 | 成人在线亚洲| 国产精品亚洲片夜色在线| 蜜桃视频在线观看www| 一区二区三区久久| 国产十八熟妇av成人一区| 亚洲精品乱码| 欧美日韩日本网| 国产精品亚洲d| 久久精品国产96久久久香蕉| 日韩在线播放中文字幕| 国产亚洲欧美日韩日本| 日本人视频jizz页码69| 国产韩日影视精品| 99电影在线观看| 在线看片国产福利你懂的| 国产视频亚洲精品| 日本一区二区网站| 久久夜色精品国产噜噜av | 亚洲女同另类| 国产成人精品免费视频大全最热| 麻豆传媒在线观看| 精品噜噜噜噜久久久久久久久试看| 三区四区在线观看| 韩国成人精品a∨在线观看| 日本大片免费看| 国产成人1区| 成人情趣片在线观看免费| 182在线视频观看| 亚洲天堂男人天堂女人天堂| 国产又黄又粗又猛又爽| 久久久欧美精品sm网站| 国产中文字幕在线免费观看| 精品国产一区二区三区久久久蜜臀| 91爱视频在线| 日av在线播放| 337p亚洲精品色噜噜狠狠| 国产精品第108页| 国产精品欧美综合在线| 在线xxxxx| 蜜臀91精品一区二区三区| 无码熟妇人妻av在线电影| 欧美经典一区| 欧美激情亚洲视频| 高清美女视频一区| 亚洲第一视频网| 中文字幕观看在线| 精品magnet| 免费国产羞羞网站美图| 91农村精品一区二区在线| 九九久久久久久| 久久久人人人| 免费在线观看视频a| 成人同人动漫免费观看| 国产亚洲欧美一区二区三区| 国产精品第一国产精品| 57pao精品| 黄色毛片在线观看| 亚洲精品一区二区精华| 91丨porny丨在线中文 | 亚洲在线资源| 欧美又大又硬又粗bbbbb| 1024在线播放| 中文字幕日韩av| 免费在线视频一级不卡| 91福利社在线观看| 亚洲精品午夜国产va久久成人| 久久综合九色综合欧美亚洲| 青青在线视频免费| 亚洲最黄网站| 欧美男女爱爱视频| 欧美天天视频| 女人床在线观看| 农村少妇一区二区三区四区五区| 青青a在线精品免费观看| 大片免费播放在线视频| 亚洲男女自偷自拍图片另类| 你懂的网站在线| 欧美艳星brazzers| 国语对白永久免费| 五月婷婷综合网| 日韩精品乱码久久久久久| 久久日韩精品一区二区五区| 在线免费av播放| 久久综合婷婷| 国产精品乱码久久久久| 性久久久久久| 99精品一区二区三区的区别| 久久综合国产| 男人天堂成人网| 亚洲v天堂v手机在线| 精品国产乱码久久久久久丨区2区 精品国产乱码久久久久久蜜柚 | 麻豆视频久久| 51精品在线观看| 欧美久久天堂| 欧美专区在线视频| 日韩一区二区三区在线免费观看| 欧美乱大交做爰xxxⅹ性3| av网址在线看| 久久久久久成人| 麻豆免费在线| 欧美高清视频在线| 91黄页在线观看| 日本一区二区三区在线播放| 午夜小视频福利在线观看| 色在人av网站天堂精品| 1区2区3区在线| 麻豆国产精品va在线观看不卡| 欧洲毛片在线| 国产亚洲在线播放| 免费网站黄在线观看| 欧美大肥婆大肥bbbbb| 污污在线观看| 欧美一区二区三区免费观看| 欧美极品免费| 日本精品在线视频| 精品国产美女a久久9999| 91精品视频网站| 激情小说亚洲色图| 青青草原亚洲| 中文av一区| 3d动漫一区二区三区| 中文字幕免费一区二区三区| 国产中文字幕乱人伦在线观看| 91精品婷婷色在线观看| 日韩精品在线视频免费观看| 性色一区二区三区| 波多野结衣国产精品| 懂色av一区二区在线播放| 极品白嫩丰满美女无套| 国产精品久久精品日日| 久久精品无码一区| 日韩美女精品在线| 国产一区在线观看免费| 亚洲国产一区二区视频| 亚洲 小说区 图片区| 欧美性猛交一区二区三区精品| av资源免费观看| 狠狠躁夜夜躁人人爽天天天天97| 五月天婷婷丁香| 欧美日韩一区二区三区视频| 丰满人妻一区二区三区四区53| 日韩美女天天操| 亚洲精品字幕在线观看| 国产亚洲精品久久| heyzo高清国产精品| 国产剧情日韩欧美| 欧美福利在线播放网址导航| 久久久国产精华液999999| 国产日本精品| 成人免费无码av| 国产福利一区在线| 久久一区二区电影| 久久日韩精品一区二区五区| 亚洲色图综合区| 亚洲成人午夜电影| 天天干天天干天天操| 日韩午夜激情av| 一级毛片视频在线| 热久久免费国产视频| 大型av综合网站| 免费cad大片在线观看| 久久国产综合精品| 欧洲女同同性吃奶| 都市激情亚洲色图| 亚洲精选一区二区三区| 久久天天躁日日躁| av美女在线观看| 2022国产精品| 亚洲一区二区三区无吗| 777视频在线| 国产日韩v精品一区二区| 日韩少妇高潮抽搐| 亚洲精品在线一区二区| 超碰在线caoporen| 91在线中文字幕| 天堂美国久久| 9l视频白拍9色9l视频| 国产清纯白嫩初高生在线观看91| 欧美性生交大片| 欧美天堂亚洲电影院在线播放| av网站免费播放| 久久久av网站| 中文一区一区三区高中清不卡免费| 国产精品视频内| 国产乱码精品一区二区亚洲| 成人性做爰片免费视频| 99热精品在线| 午夜免费福利视频在线观看| 成人精品国产福利| 日产欧产va高清| 亚洲精品一区二三区不卡| 深夜成人在线| 欧洲成人一区二区| 日本在线播放一区二区三区| 精品无码国产污污污免费网站| 亚洲男人都懂的| 99在线精品视频免费观看软件| 亚洲欧美成人网| 3d欧美精品动漫xxxx无尽| 日韩精品一线二线三线| 青草av.久久免费一区| avtt香蕉久久| 日本丶国产丶欧美色综合| 成人影视在线播放| 国产欧美日韩高清| 中文字幕人成人乱码| 色悠悠在线视频| 色综合天天综合色综合av| 免费在线黄色影片| 欧美极品欧美精品欧美视频| 成人在线tv视频| 欧美日韩在线视频一区二区三区| 国产精品资源站在线| 国产一级视频在线| 日韩视频一区在线观看| h视频在线播放| 91在线视频一区| 一本色道88久久加勒比精品| 美女100%无挡| 欧美高清视频一二三区 | 欧美精品一区二区三区蜜臀 | 精品视频在线观看网站| 91大学生片黄在线观看| 91亚洲国产成人精品一区二三| 久久免费视频播放| 亚洲欧美日韩天堂| 国产精品一区三区在线观看| 在线播放豆国产99亚洲| 国产91色综合久久免费分享| 欧美激情黑白配| 久久久国产一区二区| 精品福利在线| 国产二级片在线观看| 国产精品久久久久久久第一福利 | 日韩女优av电影| 成人在线观看亚洲| 国模精品娜娜一二三区| 蜜桃av噜噜一区| 日韩av综合在线| 久久精品国产2020观看福利| 精品午夜电影| 五月六月丁香婷婷| 在线看日本不卡| av不卡高清|