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

MySQL 啥時候用記錄鎖,啥時候用間隙鎖?

數據庫 MySQL
我們做了這么多個測試,雖然有 3 種索引類型(聚簇索引、唯一二級索引、普通二級索引)和 2 種匹配類型(精確匹配、范圍匹配),它們兩兩組合可以得出 6 種情況,再加上查詢的值是否存在,可能有更多的可能性。但是我們發現它們的結構都非常類似,基本上都跟查找的記錄是否存在,以及查找的記錄是否是唯一的相關。

大家好,我是樹哥。

在前面的文章「MySQL 不同隔離級別,都使用了什么鎖?」里,我們得出結論:在「讀未提交」和「讀已提交」隔離級別下,都只會使用記錄鎖,不會用間隙鎖和 Next-Key 鎖。而對于「可重復讀」隔離級別來說,會使用記錄鎖、間隙鎖和 Next-Key 鎖。

那么 MySQL 啥時候會用記錄鎖,啥時候會用間隙鎖,啥時候又會用 Next-Key 鎖呢?今天我們就來做一些測試,弄清楚這個問題。

圖片

文章思維導圖

影響因素

在開始之前,我們需要聲明的是:本文所有測試及結論的前提均是在「可重復讀」隔離級別下,以及 Innodb 存儲疫情下。

根據網上資料,我們大概可以知道,影響其使用哪種行級鎖的因素有:

  • 索引類型(聚簇索引、唯一二級索引、普通二級索引)
  • 匹配類型(精確匹配、唯一匹配、范圍匹配)
  • 事務隔離級別
  • 是否開啟 Innodb_locks_unsafe_for_binlog 系統變量
  • 記錄是否被標記刪除
  • 具體的執行語句類型(SELECT、INSERT、DELETE、UPDATE)

為了讓文章相對易懂一些,我準備重點測試索引類型與匹配類型兩個影響因素。對于其他的影響因素,我將不做改動。例如:事務隔離級別固定為「可重復讀」,Innodb_locks_unsafe_for_binlog 固定為 false。而第 5、6 點相對來說簡單一些,則我們會簡單帶過。

針對上面幾個影響因素,我們指定了幾個測試實驗,分別是:

  • 聚簇索引 + 精確匹配
  • 聚簇索引 + 范圍匹配
  • 唯一二級索引 + 精確匹配
  • 唯一二級索引 + 范圍匹配
  • 普通二級索引 + 精確匹配
  • 普通二級索引 + 范圍匹配
// 表結構
CREATE TABLE `test`.`price_test` (
`id` BIGINT(64) NOT NULL AUTO_INCREMENT,
`price` INT(4) NULL,
PRIMARY KEY (`id`));
// 表中數據
1, apple, 10
2, orange, 30
50, perl, 60

聚簇索引 + 精確匹配

為了測試「聚簇索引 + 精確匹配」下加鎖的類型,我們采用如下的測試方法。

事務 A 執行下面命令:

begin;
select * from price_test where id = 2 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

圖片

可以看到,其是對 id 為 2 的索引加了一個記錄鎖。

此時事務 B 執行下面命令:

beign;
update price_test set price = 25 where id = 2;

執行之后,我們會發現事務 B 阻塞住了。

那如果聚簇索引的值找不到對應的記錄呢,將會是一個什么樣的結果呢?

我們再來測試一下,開始之前記得將事務 A 和 B 回滾恢復。

事務 A 執行下面命令,其中 id 為 5 的記錄是不存在的:

begin;
select * from price_test where id = 5 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,其加了一個間隙鎖,該間隙鎖應該是 (2, 50) 這個范圍。

我們可以通過在事務 B 執行如下命令來測試下間隙鎖的范圍。

beign;
// 執行下面任何一個命令,可以通過
update price_test set price = 25 where id = 2;
update price_test set price = 25 where id = 50;
// 執行下面任何一個命令,都將阻塞
insert into price_test(id,name,price) values(3,"test",25);
insert into price_test(id,name,price) values(5,"test",25);
insert into price_test(id,name,price) values(49,"test",25);

由此我們可以得出結論:「聚簇索引 + 精確匹配」,如果能夠定位到唯一一條存在的記錄,那么其會使用記錄鎖。如果該記錄不存在,那么則會使用間隙鎖。

聚簇索引 + 范圍匹配

事務 A 執行下面命令:

begin;
select * from price_test where id >= 2 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,事務 A 一共加了 3 個鎖,其中 1 個記錄鎖,2 個 Next-Key 鎖。其中 1 個記錄鎖是對 id 為 2 的索引加的鎖,Next-Key 鎖是對 (2, 50] 和 (50, 正無窮) 這兩個區間加的鎖。

在事務 B 執行下面命令可以驗證間隙鎖的加鎖區間:

beign;
// 執行下面任意一條語句,都會阻塞
update price_test set price = 25 where id = 2;
update price_test set price = 25 where id = 50;
insert into price_test(id,name,price) values(5,"test",25);
insert into price_test(id,name,price) values(60,"test",25);

這里我們思考一下,如果范圍匹配的值并不存在,那么會是什么情況呢?

即事務 A 執行如下語句,其中 id 為 5 的記錄是不存在的。

begin;
select * from price_test where id >= 5 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,其實加了 2 個 Next-Key 鎖,鎖的范圍應該是 (2, 50) 和 [50, + 無窮)。

此時事務 B 執行下面命令,應該都會阻塞。

beign;
// 執行下面任意一條語句,都會阻塞
update price_test set price = 25 where id = 50;
insert into price_test(id,name,price) values(5,"test",25);
insert into price_test(id,name,price) values(45,"test",25);
insert into price_test(id,name,price) values(60,"test",25);

由此我們可以得出結論:「聚簇索引 + 范圍匹配」,會使用「記錄鎖 + 間隙鎖 + Next-Key 鎖」。

唯一二級索引 + 精確匹配

事務 A 執行下面命令:

begin;
select * from price_test where price = 10 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,其加的行級鎖是 2 個記錄鎖,應該是 price = 10 這條索引記錄的鎖。

此時,如果在事務 B 執行下面命令:

beign;
// 執行下面任意一條語句,都會阻塞
update price_test set name = 'test-name' where price = 10;

執行之后,我們會發現事務 B 阻塞住了。

由此我們可以得出結論:唯一二級索引與聚簇索引非常類似,都只有一個唯一值,都是使用記錄鎖。

唯一二級索引 + 范圍匹配

事務 A 執行下面命令:

begin;
select * from price_test where price >= 30 for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,事務 A 一共有 5 個行鎖,其中 3 個 Next-Key 鎖, 2 個記錄鎖。大致可以猜測出兩個記錄鎖分別是 price 為 30 和 60 的記錄鎖。3 個 Next-Key 鎖則是 (10, 30)、(30,60)、(60, 正無窮)三個范圍。

為了驗證我們上面的結論,我們在事務 B 執行下面命令,每條 SQL 都會阻塞住:

beign;
// 執行下面任意一條語句,都會阻塞
update price_test set name = 'price30' where price = 30;
update price_test set name = 'price60' where price = 60;
insert into price_test(id,name,price) values(5,"test", 20);
insert into price_test(id,name,price) values(5,"test", 40);
insert into price_test(id,name,price) values(5,"test", 70);

執行之后,我們會發現事務 B 阻塞住了。

由此我們可以得出結論:「唯一二級索引 + 范圍匹配」,會使用「記錄鎖 + 間隙鎖 + Next-Key 鎖」。

普通二級索引 + 精確匹配

事務 A 執行下面命令:

begin;
select * from price_test where name = 'apple' for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

可以看到,其不僅有一個記錄鎖,還有一個間隙鎖。這里可以猜測記錄鎖是 apple 索引的記錄鎖,而間隙鎖則是 (負無窮,orange) 的間隙鎖。

我們可在事務 B 執行如下命令驗證一下:

begin;
// 執行下面任意一條語句,都會阻塞
update price_test set name = 'apple-new' where name = 'apple';
insert into price_test(id,name,price) values(5,"aa", 20);
insert into price_test(id,name,price) values(5,"ha", 20);
// 執行下面的語句正常執行
update price_test set name = 'orange-new' where name = 'orange';
insert into price_test(id,name,price) values(5,"orb", 20);

之所以二級索引的精確匹配會有間隙鎖,是因為二級索引可能匹配到多個。因此當匹配到一個的時候,會繼續往后匹配,直到匹配到一個不符合的記錄,隨后就會以該不符合的記錄(這里是 orange)作為值做一個間隙鎖。

由此我們可以得出結論:「普通二級索引 + 精確匹配」,會使用「記錄鎖 + 間隙鎖 + Next-Key 鎖」。

普通二級索引 + 范圍匹配

事務 A 執行下面命令:

begin;
select * from price_test where name >= 'orange' for update;

執行 show engine innodb status\G; 查看鎖信息如下圖所示。

圖片

從上圖可以看到起一共有 2 個記錄鎖,3 個 Next-Key 鎖。其中 2 個記錄鎖應該是 orange 和 perl 兩個記錄,3 個 Next-Key 鎖,應該是 (apple, orange]、[orange, perl)、[perl, 正無窮)。

我們可在事務 B 執行如下命令驗證一下:

begin;
// 執行下面任意一條語句,都會阻塞
// 驗證記錄鎖
update price_test set price = 1 where name = 'orange';
update price_test set price = 1 where name = 'perl';
// 驗證間隙鎖
insert into price_test(id,name,price) values(5,"ba", 20);
insert into price_test(id,name,price) values(5,"orb", 20);
insert into price_test(id,name,price) values(5,"pes", 20);
// 執行下面的語句正常執行
update price_test set price = 1 where name = 'apple';
insert into price_test(id,name,price) values(5,"aa", 20);

可以看到「普通二級索引 + 范圍匹配」與「普通二級索引 + 精確匹配」結果是類似的。

我們可以得出結論:「普通二級索引 + 范圍匹配」,會使用「記錄鎖 + 間隙鎖 + Next-Key 鎖」。

總結

我們做了這么多個測試,雖然有 3 種索引類型(聚簇索引、唯一二級索引、普通二級索引)和 2 種匹配類型(精確匹配、范圍匹配),它們兩兩組合可以得出 6 種情況,再加上查詢的值是否存在,可能有更多的可能性。但是我們發現它們的結構都非常類似,基本上都跟查找的記錄是否存在,以及查找的記錄是否是唯一的相關。

由此,我們大致可以得出結論:

  1. 如果查找的記錄是唯一且存在的,那么只會使用記錄鎖,而不會使用間隙鎖或 Next-Key 鎖。
  2. 如果查找的記錄不唯一或者不存在,那么就會使用 Next-Key 鎖和間隙鎖。

通過這次測試,我們大概知道了加鎖的一些原則,但實際上 Innodb 的關于加鎖的源碼還是比較復雜的。有一篇文章講得還是比較好的,本文可以說是做了一些簡化,有興趣的朋友可以自行閱讀看看:完整版:Innodb 到底是怎么加鎖的。

參考資料

  • 完整版:Innodb 到底是怎么加鎖的
  • 【鎖】MySQL 間隙鎖 - 阿里云開發者社區
  • MySQL next-key lock 加鎖范圍是什么?- SegmentFault 思否
責任編輯:武曉燕 來源: 樹哥聊編程
相關推薦

2022-07-20 08:06:57

MySQL表鎖Innodb

2020-01-15 07:43:45

架構redis開發

2025-06-04 02:55:00

MySQL意向鎖記錄鎖

2022-04-29 11:39:28

MySQL幻讀Gap Lock

2023-12-06 07:33:20

MySQL鎖事間隙鎖

2019-08-23 07:58:51

GDPR安全隱私數據安全

2021-12-26 00:48:05

一致性視圖數據庫

2020-10-20 13:50:47

MySQL數據庫

2023-11-06 08:35:08

表鎖行鎖間隙鎖

2024-08-07 14:58:00

MySQL釋放鎖核心模塊

2015-07-08 15:55:01

NSStringcopystrong

2024-08-09 09:00:00

Akamai云服務

2020-07-02 08:22:56

MySQL間隙鎖過行鎖

2021-06-07 07:59:37

MySQL 全局鎖線程

2025-11-10 08:41:06

2021-12-14 08:10:00

MySQL行鎖間隙鎖

2022-09-08 08:02:26

MySQL隔離

2021-01-12 20:28:51

Windows10X微軟應用

2024-05-20 09:58:27

2010-11-09 13:58:03

SQL Server鎖
點贊
收藏

51CTO技術棧公眾號

国产网友自拍视频| 国模无码视频一区二区三区| 国产精品亚洲欧美在线播放| 欧美韩日精品| 日韩黄色高清视频| 国产精品视频黄色| 1区2区在线观看| 本田岬高潮一区二区三区| 97超级碰碰碰| 亚洲av熟女国产一区二区性色| 欧美极品在线| 欧美日韩美女在线观看| 在线观看欧美激情| 日韩在线视频免费| 蜜臀av一区二区在线观看| 欧美成人午夜免费视在线看片| 给我看免费高清在线观看| 91成人福利社区| 黄色成人av网| 美女黄色片网站| 欧美777四色影视在线 | 韩剧1988在线观看免费完整版| 日本精品在线观看视频| 一区二区三区四区高清视频 | av有声小说一区二区三区| 亚洲欧洲精品成人久久奇米网| 国产综合欧美在线看| 一级片免费网站| 欧美亚洲一区二区三区| 欧美疯狂做受xxxx高潮| avhd101老司机| 日韩欧美天堂| 精品毛片乱码1区2区3区| 国产日韩欧美久久| 婷婷六月国产精品久久不卡| 亚洲国产精品一区二区久久恐怖片| 日韩欧美在线观看强乱免费| 婷婷五月综合久久中文字幕| 国产精品亚洲第一| 91精品视频免费看| 在线免费看av的网站| 亚洲一区二区三区免费在线观看| 欧美多人乱p欧美4p久久| 中文乱码字幕高清一区二区| 久草成人资源| 日韩精品视频中文在线观看| 欧美日韩一区二区区别是什么 | 国产精品久久国产精品99gif| 久久香蕉精品视频| 欧美精品成人| 欧美精品在线网站| 欧美片一区二区| 亚洲女同中文字幕| 美女福利精品视频| 少妇被躁爽到高潮无码文| 四虎国产精品免费观看| 中文字幕精品—区二区| 免费看91的网站| 国产一区二区三区不卡视频网站| 日韩精品在线看| 成年人网站免费看| 天堂成人娱乐在线视频免费播放网站 | 韩国成人av| 日韩一级免费毛片| 99久久伊人精品| 久久精品二区| 精品久久av| 中文字幕乱码日本亚洲一区二区| 五月天国产一区| 在线免费黄色| 18欧美乱大交hd1984| 亚洲图片在线观看| 一区二区三区伦理| 亚洲午夜久久久久久久久电影网 | 一本色道久久综合亚洲91 | 爱情岛论坛亚洲品质自拍视频网站| 亚洲精品v日韩精品| 成人在线免费高清视频| а_天堂中文在线| 精品日韩美女的视频高清| 国内自拍在线观看| 影视一区二区三区| 欧美一区二区三区啪啪| 精品久久久久一区二区| 校花撩起jk露出白色内裤国产精品 | 97精品国产97久久久久久免费 | 亚洲日本黄色| 国产成人精品视频在线观看| 午夜一级黄色片| 国产一区二区三区免费看| 99九九电视剧免费观看| 三级av在线播放| 国产精品免费久久| 国产一二三区在线播放| 色老太综合网| 日韩手机在线导航| 蜜桃精品一区二区| 久久精品国内一区二区三区水蜜桃 | 91在线看www| 日韩一级片免费观看| 国产女同性恋一区二区| 免费cad大片在线观看| 黄频免费在线观看| 欧美日韩精品欧美日韩精品| 欧洲成人午夜精品无码区久久| 亚洲国产精品嫩草影院久久av| xvideos成人免费中文版| 欧美一级高潮片| 日本人妖一区二区| 国产另类自拍| 亚洲xxxxxx| 精品福利在线观看| 91aaa精品| 国产精品三级| 国外成人免费在线播放| 97免费观看视频| 久久久影视传媒| 好吊色视频988gao在线观看| 久久爱91午夜羞羞| 精品国产乱码久久久久久久久| 精品欧美一区二区久久久| 国产精品久久| 成人免费网视频| 九色在线视频| 亚洲国产毛片aaaaa无费看 | 久久久加勒比| 亚洲精品在线91| 国产亚洲精品av| 久久激情五月激情| 免费国产在线精品一区二区三区| 在线中文字幕视频观看| 欧美日韩一本到| 一级黄色片大全| 禁久久精品乱码| 18成人免费观看网站下载| 搞黄视频免费在线观看| 精品久久久久久国产91| 亚洲欧美日韩偷拍| 欧美日韩三级| 91久久久久久国产精品| av资源网站在线观看| 一本一道久久a久久精品| 久久国产精品无码一级毛片| 亚洲一级电影| 91久久久一线二线三线品牌| 91在线中文| 欧美精品一二三区| 艳妇荡乳欲伦69影片| 秋霞成人午夜伦在线观看| 美女视频久久| 中文在线а√天堂| 国产婷婷成人久久av免费高清| 国产大片中文字幕| 国产suv一区二区三区88区| 无码人妻精品一区二区三区99v| 欧美亚洲福利| 久久精品国产免费观看| 一级成人免费视频| 中文字幕永久在线不卡| 99日在线视频| 91精品天堂福利在线观看| 国产日韩欧美在线看| 久久bbxx| 日韩一区二区视频在线观看| 欧美成人一区二区三区高清| 国产盗摄精品一区二区三区在线| 欧美另类videos| 日韩成人视屏| 久久久免费精品| 香蕉视频国产在线| 色先锋久久av资源部| 一级黄色录像毛片| 久久aⅴ国产欧美74aaa| 欧洲精品视频在线| 国产另类在线| 性欧美激情精品| 久草福利在线视频| 欧美日韩国产美女| 欧美日韩人妻精品一区二区三区| 粉嫩aⅴ一区二区三区四区五区| 自拍日韩亚洲一区在线| 亚欧日韩另类中文欧美| 国产噜噜噜噜久久久久久久久| 黄色网址免费在线观看| 欧美成人欧美edvon| 国产成人自拍视频在线| 国产视频911| 人妻体体内射精一区二区| 亚洲一区成人| 亚洲第一精品区| 国产精品男女| 国产精品无av码在线观看| 日本孕妇大胆孕交无码| 亚洲欧美第一页| 国产偷拍一区二区| 日韩欧美极品在线观看| 网站永久看片免费| 波多野结衣在线aⅴ中文字幕不卡| 可以免费观看av毛片| 2023国产精品久久久精品双| 久久精品二区| 青草伊人久久| 国产suv精品一区二区| 亚洲综合影视| 亚洲最新av网址| 成人av一区二区三区在线观看| 日韩欧美在线字幕| 欧美性猛交xxxxx少妇| 久久久综合激的五月天| 亚洲av无码久久精品色欲| 视频在线在亚洲| 日韩免费在线观看av| 欧洲三级视频| 精品婷婷色一区二区三区蜜桃| 成人a在线观看高清电影| 韩国v欧美v日本v亚洲| 日本福利专区在线观看| 亚洲精品一区中文字幕乱码| 国产伦精品一区二区三区四区 | 日本黄网站色大片免费观看| 国产精品手机在线播放 | 欧美日韩xxxxx| 丝袜美腿美女被狂躁在线观看| 亚洲精品美女在线观看| 999精品国产| 欧美日韩一级片网站| 69成人免费视频| 亚洲国产精品自拍| 久久久久久久国产视频| 国产精品乱人伦中文| 国产中年熟女高潮大集合| 东方欧美亚洲色图在线| 人妻换人妻仑乱| 六月丁香婷婷色狠狠久久| 欧美aⅴ在线观看| 亚洲视频大全| 青青草精品视频在线| 激情91久久| 日本五级黄色片| 自产国语精品视频| 一级全黄肉体裸体全过程| 超碰成人久久| 天堂av一区二区| 欧美精选一区二区三区| 欧美一区视久久| 美女久久久久| 欧美日韩亚洲一区二区三区在线观看 | 天天色天天爱天天射综合| 久久久久久久久艹| 亚洲香肠在线观看| 久久久久亚洲天堂| 亚洲综合精品自拍| 久久国产一级片| 亚洲一区二区欧美激情| 久久久久亚洲AV成人| 一区二区三区在线播| 一区二区视频免费看| 一区二区三区欧美激情| 欧美精品一级片| 亚洲成a人片综合在线| 日干夜干天天干| 精品久久久久久久久久久久久| 国产成人精品片| 欧美视频中文字幕在线| 欧美brazzers| 欧美三级欧美一级| 国产农村老头老太视频| 日韩区在线观看| 黄色片一区二区| 亚洲精品99久久久久| 日韩资源在线| 中文字幕欧美专区| 中文字幕免费高清电视剧网站在线观看| 免费不卡在线观看av| 182在线播放| 欧美在线视频播放| 久久天堂影院| 999国产在线| 偷拍自拍亚洲色图| 亚洲午夜精品久久| 欧美精品一级| 九色在线视频观看| 麻豆精品在线播放| 韩国av中国字幕| 久久综合九色欧美综合狠狠| 国产又粗又硬视频| 亚洲愉拍自拍另类高清精品| 五月婷婷激情视频| 欧美丰满美乳xxx高潮www| 亚洲精品喷潮一区二区三区| 亚洲欧美日韩精品| 亚洲卡一卡二| 国产精品99久久久久久久久 | 欧美日韩中文精品| 午夜精品久久久久久久爽| 亚洲欧美一区二区三区久久 | 欧美激情aaaa| 韩国精品主播一区二区在线观看 | 手机看片日韩国产| 日韩视频一区二区三区在线播放免费观看| 精品www久久久久奶水| 国产综合久久久久久鬼色| 国产吞精囗交久久久| 亚洲男女毛片无遮挡| 天天干天天操天天爱| 日韩视频国产视频| 国模精品一区二区| 久久久久久尹人网香蕉| 欧美三级电影网址| 欧美男人的天堂| 欧美日韩国产一区精品一区| 91小视频网站| 久久久久久久性| 久久成人国产精品入口| 欧美日本一区二区三区| 黄色在线网站| 91精品国产91久久久久久久久| 亚洲一区导航| 日韩成人在线资源| 在线综合欧美| 免费在线观看日韩av| 91久色porny| 欧美精品videos极品| 欧美精品三级在线观看| 天天躁日日躁狠狠躁喷水| 欧美成人免费观看| 人人精品久久| 日韩亚洲视频在线| 国产婷婷精品| 在线观看亚洲免费视频| 一区二区三区免费网站| 国产视频一区二区三区四区五区 | 色呦呦久久久| 成人黄色免费看| 成人女性视频| www.超碰com| 久久综合久久鬼色中文字| 日韩精品一区二区三| 欧美r级电影在线观看| 91三级在线| 91九色在线观看| 91久久久精品国产| 五月天av在线播放| 国产欧美精品一区| 中文字幕有码视频| 在线观看日韩专区| 久久99国产精品二区高清软件| 婷婷久久伊人| 日本va欧美va欧美va精品| 欧美做受xxxxxⅹ性视频| 色婷婷激情久久| 免费在线黄色电影| 国产成人欧美在线观看| 韩日一区二区三区| 精品少妇无遮挡毛片| 国产精品水嫩水嫩| 91麻豆成人精品国产免费网站| 日韩中文av在线| 亚洲日日夜夜| 亚洲五码在线观看视频| 国产不卡视频在线观看| 不卡的免费av| 日韩av网站大全| 国模冰冰炮一区二区| 欧美日韩综合精品| 蜜臀va亚洲va欧美va天堂| 日本激情视频一区二区三区| 欧美一区二区三区在线观看视频 | 91国产精品91| 在线日韩一区| 天堂一区在线观看| 亚洲另类中文字| 日韩一级片免费看| 国产精品久久久久77777| 91麻豆国产自产在线观看亚洲| 成人av毛片在线观看| 亚洲免费高清视频在线| 少妇一区二区三区四区| 国产成人在线亚洲欧美| 国产精品99一区二区三区| 国产伦精品一区二区三区妓女下载| 亚洲第一成人在线| 狠狠色伊人亚洲综合网站l| 91精品国产综合久久香蕉的用户体验 | 成人一区二区在线| 在线一区视频| 黄色激情小视频| 精品国精品国产| 精品国产免费人成网站| 国产高清精品软男同| 成人永久aaa| 亚洲男人天堂网址| 欧美激情一区二区三区高清视频| 亚洲+变态+欧美+另类+精品| 亚洲综合av在线播放| 欧美日韩国产综合新一区| 男人影院在线观看| 激情视频在线观看一区二区三区| 美女脱光内衣内裤视频久久网站| 免费中文字幕视频|