精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

国产伦理一区二区三区| 欧美精品视频www在线观看| 91超碰rencao97精品| 黄页网站免费观看| 欧美大奶一区二区| 欧美日韩午夜影院| www.成年人视频| 国产精品视频二区三区| 黄页视频在线91| 高清在线视频日韩欧美| 黄页网站在线看| 韩国成人漫画| 一区二区三区中文在线观看| 美女亚洲精品| 国产区精品在线| 性欧美videos另类喷潮| 久久中文字幕在线| 国产精品一二三区在线观看| 91麻豆精品激情在线观看最新| 一本大道久久a久久精品综合| 中文字幕一区二区三区四区五区| 色婷婷av一区二区三区之e本道| 秋霞影院一区二区| 91成人在线播放| 日本美女黄色一级片| 特黄特色欧美大片| 日韩欧美电影在线| 久久久久久久久久久久91| 大黄网站在线观看| 中文字幕欧美一区| 欧美一级二级三级九九九| 粉嫩小泬无遮挡久久久久久| 捆绑变态av一区二区三区| 69久久夜色精品国产69| 久草综合在线视频| 日韩电影二区| 亚洲免费视频网站| 亚洲 欧美 日韩在线| 一区在线不卡| 欧美日韩五月天| 女人另类性混交zo| 国产高清视频色在线www| 亚洲乱码国产乱码精品精的特点 | 水蜜桃色314在线观看| 黄色免费在线观看网站| 亚洲国产精品v| 欧美一级爱爱| 三级在线电影| 91亚洲精华国产精华精华液| 国产高清中文字幕| 国产欧美熟妇另类久久久| 中日韩男男gay无套| 超碰精品一区二区三区乱码| 日本在线观看网址| 成人羞羞网站入口免费| 亚洲免费视频观看| a毛片毛片av永久免费| 欧美韩一区二区| 亚洲成年人在线| 最新版天堂资源在线| 91精品尤物| 精品欧美黑人一区二区三区| 美女被爆操网站| 日韩高清一区| 精品乱码亚洲一区二区不卡| 韩国黄色一级片| 大香伊人久久精品一区二区| 日韩免费福利电影在线观看| 精品人妻二区中文字幕| 91精品国产自产精品男人的天堂| 美腿丝袜在线亚洲一区| 麻豆国产精品va在线观看不卡| 综合 欧美 亚洲日本| 婷婷激情图片久久| 久久成人免费视频| 毛片aaaaa| 黄色欧美日韩| 91精品国产九九九久久久亚洲| 日本天堂在线视频| 免费国产自线拍一欧美视频| 日韩免费在线视频| 夜夜狠狠擅视频| 国产成人午夜视频| 久久99影院| aaa在线免费观看| 最新高清无码专区| 免费看欧美黑人毛片| 电影网一区二区| 欧美精选一区二区| 麻豆传媒在线看| 欧美变态挠脚心| 中文字幕在线亚洲| 青春草在线视频| 国产高清不卡一区二区| 官网99热精品| 日中文字幕在线| 国产精品美日韩| 亚洲色图都市激情| 极品在线视频| 欧美久久久久久蜜桃| 制服丝袜在线第一页| 色棕色天天综合网| 日韩亚洲欧美成人| 日本三级2019| 久热成人在线视频| 国产日韩一区欧美| 1区2区3区在线观看| 亚洲伊人色欲综合网| 国产女女做受ⅹxx高潮| 91国产一区| 日韩av在线免费观看| 亚洲精品国产精品国自| 国产一区二区三区四区老人| 国产精品av在线| 精品国产99久久久久久宅男i| 91麻豆文化传媒在线观看| 一本色道久久99精品综合| 成人高潮aa毛片免费| 精品视频一区三区九区| av天堂一区二区| 日韩精品不卡一区二区| 91精品国产91久久久久久不卡| 亚洲一区二区人妻| 97久久超碰国产精品电影| 国产又粗又大又爽的视频| 成人性生活视频| 精品欧美乱码久久久久久1区2区| 天美传媒免费在线观看| 亚洲一区二区免费看| 91入口在线观看| 91女主播在线观看| 日韩欧美高清视频| 少妇伦子伦精品无吗| 91精品二区| 国产精品1区2区在线观看| 少妇人妻一区二区| 一区二区三区欧美日韩| 亚洲人视频在线| 精品国产网站| 欧美在线观看日本一区| 亚洲精华国产精华精华液网站| 国产精品日产欧美久久久久| 国产av无码专区亚洲精品| 久久久久久毛片免费看 | 亚洲日本va午夜在线影院| 动漫av免费观看| 欧美日韩看看2015永久免费| 久久久久久久999精品视频| 国产精品成人av在线| 日本精品在线观看视频| 国产农村妇女精品一二区| 激情小说综合网| wwwww亚洲| 精品国产免费一区二区三区四区 | 亚洲人妖av一区二区| 中文字幕丰满乱码| 久久中文视频| 国产一区视频在线| 黄网站免费在线观看| 欧美一区二区精品在线| 欧美国产日韩在线观看成人| 国内精品久久久久影院薰衣草| 在线播放豆国产99亚洲| 国产成人福利夜色影视| 色妞色视频一区二区三区四区| 在线观看国产区| 国产精品素人视频| 中文字幕第22页| 牛牛国产精品| 国产精品久久国产精品| 多野结衣av一区| 亚洲精品午夜精品| 中文字幕精品视频在线观看| 国产欧美一区二区精品秋霞影院 | 亚洲第一视频在线观看| 国产成人愉拍精品久久 | 精品一区二区6| 精品系列免费在线观看| 影音先锋成人资源网站| 91国内精品白嫩初高生| 欧美一二三视频| 国产最新视频在线| 欧美色区777第一页| 2025国产精品自拍| 大桥未久av一区二区三区中文| 青青艹视频在线| 精品视频99| 2022国产精品| 波多视频一区| 色七七影院综合| 日本韩国在线观看| 91精品办公室少妇高潮对白| sm捆绑调教视频| 成人激情免费网站| 国内自拍视频网| 国产精品v日韩精品v欧美精品网站| 精品不卡一区二区三区| 懂色aⅴ精品一区二区三区| 欧美日韩成人黄色| 久草在现在线| 日韩欧美一区在线| 亚洲毛片在线观看.| 国产成人精品一区二区色戒| 亚洲精品一二三| 成年人免费观看视频网站| 激情深爱一区二区| 成人免费在线小视频| 99欧美视频| 久久婷婷开心| 国产麻豆一区二区三区| 97超级碰碰人国产在线观看| 在线观看黄av| 日韩电视剧在线观看免费网站| 97超碰人人草| 色婷婷综合五月| 国产一级一级片| 国产精品电影院| 国产福利短视频| 国产大陆精品国产| www.com黄色片| 国产日韩欧美一区| 国产资源第一页| 欧美综合一区| 久久综合一区二区三区| 亚洲五码在线| 成人欧美一区二区三区在线湿哒哒 | 日韩脚交footjobhd| 久久天堂电影网| 成年午夜在线| 亚洲精品在线看| 亚洲产国偷v产偷v自拍涩爱| 欧美日本视频在线| 久久这里只有精品9| 婷婷亚洲久悠悠色悠在线播放| 国产精品免费人成网站酒店| 国产欧美精品一区| 日韩中文字幕电影| av中文字幕一区| 亚洲精品一二三四| 国产主播一区二区| 亚洲精品20p| 蜜桃久久久久久| 日本老熟妇毛茸茸| 久久精品五月| 黑森林福利视频导航| 99视频精品免费观看| 成人精品视频在线播放| 欧美私人啪啪vps| 国产一区二区三区小说| 欧美日韩亚洲一区二区三区在线| av电影一区二区三区| 91亚洲国产| 中文字幕乱码一区二区三区| 91久久夜色精品国产按摩| 亚洲午夜精品国产| 日韩黄色大片网站| 国产精品jizz在线观看老狼| 国产精品成人a在线观看| 亚洲精品日韩在线观看| 日韩国产综合| 干日本少妇视频| 亚洲影视一区二区三区| 在线观看18视频网站| 中文字幕一区二区三区乱码图片| 99久re热视频精品98| 伊人成人在线视频| 奇米精品一区二区三区| 亚洲免费一区二区| 88av.com| 国产一区二区三区四区五区入口| 久久人人爽人人片| 成人国产精品视频| 欧美bbbbb性bbbbb视频| 久久久国产午夜精品| 制服丨自拍丨欧美丨动漫丨| 亚洲色图欧洲色图| 久久精品视频日本| 日韩欧美国产激情| 亚洲图片欧美在线| 日韩丝袜情趣美女图片| 天堂av网在线| 一本一道久久a久久精品逆3p | 夜夜嗨aⅴ一区二区三区| 正在播放一区二区| 免费看国产片在线观看| 亚洲夜晚福利在线观看| 久久日韩视频| 国内揄拍国内精品| 91九色综合| 波多野结衣成人在线| 亚洲毛片免费看| 中文视频一区视频二区视频三区| 国色天香一区二区| 成年人在线看片| 国产一区二区三区免费看| 中文字幕av观看| 中文字幕一区二区在线观看| 国产亚洲精品女人久久久久久| 欧美午夜精品久久久久久久| 在线免费av网| 亚洲第一福利网| 日本免费在线观看| 久久久久久久久久久免费 | 深夜视频在线观看| 欧美激情一区二区三区全黄| 久久久国产精品黄毛片| 日本韩国欧美一区| www.五月婷| 夜夜嗨av色一区二区不卡| 影音先锋男人在线资源| 日本欧美爱爱爱| 91蝌蚪精品视频| 一区二区视频在线播放| 久久精品人人| 亚洲色偷偷色噜噜狠狠99网| 国产精品第四页| 亚洲大片免费观看| 精品国产免费人成在线观看| 999在线视频| 日韩av免费看| 久久精品福利| av日韩在线看| 精品一区二区免费视频| 中文字幕一二三四区| 亚洲国产精品麻豆| 国产免费不卡视频| 中文字幕在线视频日韩| 国模套图日韩精品一区二区| 国产日产精品一区二区三区四区 | 久久人人爽人人爽人人av| 九九精品视频在线看| 四虎永久免费在线观看| 精品成人av一区| 国产综合在线播放| 久久国产精品久久久久久久久久 | 永久免费在线观看视频| 日本一欧美一欧美一亚洲视频| 北条麻妃一区二区三区在线| 国产日韩第一页| 免费在线欧美视频| 久久精品无码一区| 91黄色免费版| 国产九色在线| 欧美a级一区| 中文字幕人成一区| 在线观看国产小视频| 日韩av网站导航| 日本资源在线| 亚洲自拍偷拍福利| 91精品国产乱码久久久久久| 青青草原国产在线视频| 国产人妖乱国产精品人妖| 丰满少妇xoxoxo视频| 日韩电影大全免费观看2023年上 | 欧美精品999| 日韩在线观看中文字幕| 日韩一级特黄毛片| 成人免费视频免费观看| 国产亚洲精品码| 亚洲国产三级网| 日本黄色免费在线| 欧美激情第六页| 日韩和欧美一区二区| 成人18视频免费69| 欧美一区二区三区四区五区| 中文字幕伦理免费在线视频 | 国内av在线播放| 日韩中文字幕网址| 欧美欧美在线| 成年人看的毛片| 91麻豆国产精品久久| 黄色一级视频免费看| 国产一区二区三区在线观看网站 | 精品毛片三在线观看| 日av在线播放| 国产精品极品美女在线观看免费| 精品国产一区二区三区噜噜噜| 依人在线免费视频| 曰韩精品一区二区| 午夜视频福利在线观看| 日本精品一区二区三区在线 | 老司机午夜网站| 成人黄页毛片网站| 日韩一级片中文字幕| 理论片在线不卡免费观看| 精品福利一区| 五月天婷婷激情视频| 亚洲人成网站影音先锋播放| 人妻一区二区三区免费| 青草热久免费精品视频| 亚欧美无遮挡hd高清在线视频| av漫画在线观看| 色婷婷国产精品| 麻豆视频在线观看免费| 国产日韩欧美一区二区三区四区| 日韩精品一二三四| 久久精品亚洲无码| 这里只有精品在线播放| 国产精品chinese在线观看| 久草综合在线观看|