日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

Net Core中数据库事务隔离详解——以Dapper和Mysql为例

發布時間:2023/12/4 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Net Core中数据库事务隔离详解——以Dapper和Mysql为例 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

事務隔離級別

.NET Core中的IDbConnection接口提供了BeginTransaction方法作為執行事務,BeginTransaction方法提供了兩個重載,一個不需要參數BeginTransaction()默認事務隔離級別為RepeatableRead;另一個BeginTransaction(IsolationLevel il)可以根據業務需求來修改事務隔離級別。由于Dapper是對IDbConnection的擴展,所以Dapper在執行增刪除改查時所有用到的事務需要由外部來定義。事務執行時與數據庫之間的交互如下:

從WireShark抓取的數據包來看程序和數據交互步驟依次是:建立連接-->設置數據庫隔離級別-->告訴數據庫一個事務開始-->執行數據增刪查改-->提交事務-->斷開連接


準備工作

準備數據庫:Mysql (筆者這里是:MySql 5.7.20 社區版)

創建數據庫并創建數據表,創建數據表的腳本如下:

CREATE TABLE `posts` ( ?`Id` varchar(255) NOT NULL , ?`Text` longtext NOT NULL, ?`CreationDate` datetime NOT NULL, ?`LastChangeDate` datetime NOT NULL, ?`Counter1` int(11) DEFAULT NULL, ?`Counter2` int(11) DEFAULT NULL, ?`Counter3` int(11) DEFAULT NULL, ?`Counter4` int(11) DEFAULT NULL, ?`Counter5` int(11) DEFAULT NULL, ?`Counter6` int(11) DEFAULT NULL, ?`Counter7` int(11) DEFAULT NULL, ?`Counter8` int(11) DEFAULT NULL, ?`Counter9` int(11) DEFAULT NULL, ?PRIMARY KEY (`Id`) ) ENGINE=InnoDB ?DEFAULT CHARSET=utf8;

創建.NET Core Domain類:

[Table("Posts")]public class Post{[Key] ? ?public string Id { get; set; } ? ?public string Text { get; set; } ? ?public DateTime CreationDate { get; set; } ? ?public DateTime LastChangeDate { get; set; } ? ?public int? Counter1 { get; set; } ? ?public int? Counter2 { get; set; } ? ?public int? Counter3 { get; set; } ? ?public int? Counter4 { get; set; } ? ?public int? Counter5 { get; set; } ? ?public int? Counter6 { get; set; } ? ?public int? Counter7 { get; set; } ? ?public int? Counter8 { get; set; } ? ?public int? Counter9 { get; set; }}

具體怎樣使用Dapper,請看上篇。


Read uncommitted 讀未提交

允許臟讀,即不發布共享鎖,也不接受獨占鎖。意思是:事務A可以讀取事務B未提交的數據。

優點:查詢速度快

缺點:容易造成臟讀,如果事務A在中途回滾

以下為執行臟讀的測試代碼片斷:

public static void RunDirtyRead(IsolationLevel transaction1Level,IsolationLevel transaction2Level){ ? ?var id = Guid.NewGuid().ToString(); ? ?using (var connection1 = new MySqlConnection(connStr)){connection1.Open();Console.WriteLine("transaction1 {0} Start",transaction1Level); ? ? ? ?var transaction1 = connection1.BeginTransaction(transaction1Level);Console.WriteLine("transaction1 插入數據 Start"); ? ? ? ?var sql = "insert into posts (id,text,CreationDate,LastChangeDate) values(@Id,@Text,@CreationDate,@LastChangeDate)"; ? ? ? ?var detail1 = connection1.Execute(sql, ? ? ? ?new Post{Id = id,Text = Guid.NewGuid().ToString(),CreationDate = DateTime.Now,LastChangeDate = DateTime.Now},transaction1);Console.WriteLine("transaction1 插入End 返回受影響的行:{0}", detail1); ? ? ? ?using (var connection2 = new MySqlConnection(connStr)){connection2.Open();Console.WriteLine("transaction2 {0} Start",transaction2Level); ? ? ? ? ? ?var transaction2 = connection2.BeginTransaction(transaction2Level);Console.WriteLine("transaction2 查詢數據 Start"); ? ? ? ? ? ?var result = connection2.QueryFirstOrDefault<Post>("select * from posts where id=@Id", new { id = id }, transaction2); ? ? ? ? ? ?//如果result為Null 則程序會報異常Console.WriteLine("transaction2 查詢結事 返回結果:Id={0},Text={1}", result.Id, result.Text);transaction2.Commit();Console.WriteLine("transaction2 {0} End",transaction2Level);}transaction1.Rollback();Console.WriteLine("transaction1 {0} Rollback ",transaction1Level);}}

1、當執行RunDirtyRead(IsolationLevel.ReadUncommitted,IsolationLevel.ReadUncommitted),即事務1和事務2都設置為ReadUncommitted時結果如下:

當事務1回滾以后,數據庫并沒有事務1添加的數據,所以事務2獲取的數據是臟數據。

2、當執行RunDirtyRead(IsolationLevel.Serializable,IsolationLevel.ReadUncommitted),即事務1隔離級別為Serializble,事務2的隔離級別設置為ReadUncommitted,結果如下:

3、當執行RunDirtyRead(IsolationLevel.ReadUncommitted,IsolationLevel.ReadCommitted);,即事務1隔離級別為ReadUncommitted,事務2的隔離級別為Readcommitted,結果如下:

結論:當事務2(即取數據事務)隔離級別設置為ReadUncommitted,那么不管事務1隔離級別為哪一種,事務2都能將事務1未提交的數據得到;但是測試結果可以看出當事務2為ReadCommitted則獲取不到事務1未提交的數據從而導致程序異常。


Read committed 讀取提交內容

這是大多數數據庫默認的隔離級別,但是,不是MySQL的默認隔離級別。讀取數據時保持共享鎖,以避免臟讀,但是在事務結束前可以更改數據。

優點:解決了臟讀的問題

缺點:一個事務未結束被另一個事務把數據修改后導致兩次請求的數據不一致

測試重復讀代碼片斷:

public static void RunRepeatableRead(IsolationLevel transaction1Level, IsolationLevel transaction2Level){ ? ?using (var connection1 = new MySqlConnection(connStr)){connection1.Open(); ? ? ? ?var id = "c8de065a-3c71-4273-9a12-98c8955a558d";Console.WriteLine("transaction1 {0} Start", transaction1Level); ? ? ? ?var transaction1 = connection1.BeginTransaction(transaction1Level);Console.WriteLine("transaction1 第一次查詢開始"); ? ? ? ?var sql = "select * from posts where id=@Id"; ? ? ? ?var detail1 = connection1.QueryFirstOrDefault<Post>(sql, new { Id = id }, transaction1);Console.WriteLine("transaction1 第一次查詢結束,結果:Id={0},Counter1={1}", detail1.Id, detail1.Counter1); ? ? ? ?using (var connection2 = new MySqlConnection(connStr)){connection2.Open();Console.WriteLine("transaction2 ?{0} Start", transaction2Level); ? ? ? ? ? ?var transaction2 = connection2.BeginTransaction(transaction2Level); ? ? ? ? ? ?var updateCounter1=(detail1.Counter1 ?? 0) + 1;Console.WriteLine("transaction2 ?開始修改Id={0}中Counter1的值修改為:{1}", id,updateCounter1); ? ? ? ? ? ?var result = connection2.Execute( ? ? ? ? ? ? ? ?"update posts set Counter1=@Counter1 where id=@Id", ? ? ? ? ? ? ? ?new { Id = id, Counter1 = updateCounter1 },transaction2);Console.WriteLine("transaction2 修改完成 返回受影響行:{0}", result);transaction2.Commit();Console.WriteLine("transaction2 {0} End", transaction2Level);}Console.WriteLine("transaction1 第二次查詢 Start"); ? ? ? ?var detail2 = connection1.QueryFirstOrDefault<Post>(sql, new { Id = id }, transaction1);Console.WriteLine("transaction1 第二次查詢 End 結果:Id={0},Counter1={1}", detail2.Id, detail2.Counter1);transaction1.Commit();Console.WriteLine("transaction1 {0} End", transaction1Level);} }

在事務1中detail1中得到的Counter1為1,事務2中將Counter1的值修改為2,事務1中detail2得到的Counter1的值也會變為2

下面分幾種情況來測試:

1、當事務1和事務2都為ReadCommitted時,結果如下:

2、當事務1和事務2隔離級別都為RepeatableRead時,執行結果如下:

3、當事務1隔離級別為RepeatableRead,事務2隔離級別為ReadCommitted時執行結果如下:

4、當事務1隔離級別為ReadCommitted,事務2隔離級別為RepeatableRead時執行結果如下:

結論:當事務1隔離級別為ReadCommitted時數據可重復讀,當事務1隔離級別為RepeatableRead時可以不可重復讀,不管事務2隔離級別為哪一種不受影響。

注:在RepeatableRead隔離級別下雖然事務1兩次獲取的數據一致,但是事務2已經是將數據庫中的數據進行了修改,如果事務1對該條數據進行修改則會對事務2的數據進行覆蓋。

Repeatable read (可重讀)

這是MySQL默認的隔離級別,它確保同一事務的多個實例在并發讀取數據時,會看到同樣的數據行(目標數據行不會被修改)。

優點:解決了不可重復讀和臟讀問題

缺點:幻讀

測試幻讀代碼

public static void RunPhantomRead(IsolationLevel transaction1Level, IsolationLevel transaction2Level){ ? ?
using (var connection1 = new MySqlConnection(connStr)){connection1.Open();Console.WriteLine("transaction1 {0} Start", transaction1Level); ? ?
? ?var transaction1 = connection1.BeginTransaction(transaction1Level);Console.WriteLine("transaction1 第一次查詢數據庫 Start"); ? ? ?
? ??var detail1 = connection1.Query<Post>("select * from posts").ToList();Console.WriteLine("transaction1 第一次查詢數據庫 End 查詢條數:{0}", detail1.Count); ? ?
? ?? ? ?using (var connection2 = new MySqlConnection(connStr)){connection2.Open();Console.WriteLine("transaction2 {0} Start", transaction2Level); ? ? ? ? ?
? ?? ? ??var transaction2 = connection2.BeginTransaction(transaction2Level);Console.WriteLine("transaction2 執行插入數據 Start"); ? ? ? ? ?
? ?? ? ?? ?var sql = "insert into posts (id,text,CreationDate,LastChangeDate) values(@Id,@Text,@CreationDate,@LastChangeDate)"; ? ? ? ? ? ?var entity = new Post{Id = Guid.NewGuid().ToString(),Text = Guid.NewGuid().ToString(),CreationDate = DateTime.Now,LastChangeDate = DateTime.Now}; ? ? ? ? ? ?var result = connection2.Execute(sql, entity, transaction2);Console.WriteLine("transaction2 執行插入數據 End 返回受影響行:{0}", result);transaction2.Commit();Console.WriteLine("transaction2 {0} End", transaction2Level);}Console.WriteLine("transaction1 第二次查詢數據庫 Start"); ? ? ?
? ?? ??var detail2 = connection1.Query<Post>("select * from posts").ToList();Console.WriteLine("transaction1 第二次查詢數據庫 End 查詢條數:{0}", detail2.Count);transaction1.Commit();Console.WriteLine("transaction1 {0} End", transaction1Level);} }

分別對幾種情況進行測試:

1、事務1和事務2隔離級別都為RepeatableRead,結果如下:

2、事務1和事務2隔離級別都為Serializable,結果如下:

3、當事務1的隔離級別為Serializable,事務2的隔離級別為RepeatableRead時,執行結果如下:

4、當事務1的隔離級別為RepeatableRead,事務2的隔離級別為Serializable時,執行結果如下:

結論:當事務隔離級別為RepeatableRead時雖然兩次獲取數據條數相同,但是事務2是正常將數據插入到數據庫當中的。當事務1隔離級別為Serializable程序異常,原因接下來將會講到。

Serializable 序列化

這是最高的事務隔離級別,它通過強制事務排序,使之不可能相互沖突,從而解決幻讀問題。

優點:解決幻讀

缺點:在每個讀的數據行上都加了共享鎖,可能導致大量的超時和鎖競爭

當執行RunPhantomRead(IsolationLevel.Serializable, IsolationLevel.Serializable)或執行RunPhantomRead(IsolationLevel.Serializable, IsolationLevel.RepeatableRead)時代碼都會報異常,是因為Serializable隔離級別下強制事務以串行方式執行,由于這里是一個主線程上第一個事務未完時執行了第二個事務,但是第二個事務必須等到第一個事務執行完成后才參執行,所以就會導致程序報超時異常。這里將代碼作如下修改:

using (var connection1 = new MySqlConnection(connStr)) {connection1.Open();Console.WriteLine("transaction1 {0} Start", transaction1Level); ?
?var transaction1 = connection1.BeginTransaction(transaction1Level);Console.WriteLine("transaction1 第一次查詢數據庫 Start"); ?
??var detail1 = connection1.Query<Post>("select * from posts").ToList();Console.WriteLine("transaction1 第一次查詢數據庫 End 查詢條數:{0}", detail1.Count);Thread thread = new Thread(new ThreadStart(() =>{ ? ? ? ?using (var connection2 = new MySqlConnection(connStr)){connection2.Open();Console.WriteLine("transaction2 {0} Start", transaction2Level); ? ?
?? ? ? ? ?var transaction2 = connection2.BeginTransaction(transaction2Level);Console.WriteLine("transaction2 執行插入數據 Start"); ? ?
?? ? ? ? ???var sql = "insert into posts (id,text,CreationDate,LastChangeDate) values(@Id,@Text,@CreationDate,@LastChangeDate)"; ? ? ? ? ?
?? ? ? ? ? ?var entity = new Post{Id = Guid.NewGuid().ToString(),Text = Guid.NewGuid().ToString(),CreationDate = DateTime.Now,LastChangeDate = DateTime.Now}; ? ? ? ? ? ?var result = connection2.Execute(sql, entity, transaction2);Console.WriteLine("transaction2 執行插入數據 End 返回受影響行:{0}", result);transaction2.Commit();Console.WriteLine("transaction2 {0} End", transaction2Level);}}));thread.Start(); ? ?//為了證明兩個事務是串行執行的,這里讓主線程睡5秒Thread.Sleep(5000);Console.WriteLine("transaction1 第二次查詢數據庫 Start"); ?
?? ?var detail2 = connection1.Query<Post>("select * from posts").ToList();Console.WriteLine("transaction1 第二次查詢數據庫 End 查詢條數:{0}", detail2.Count);transaction1.Commit();Console.WriteLine("transaction1 {0} End", transaction1Level); }

執行結果如下:


結論:當事務1隔離級別為Serializable時對后面的事務的增刪改改操作進行強制排序。避免數據出錯造成不必要的麻煩。

注:在.NET Core中IsolationLevel枚舉值中還提供了另外三種隔離級別:Chaos、Snapshot、Unspecified由于這種事務隔離級別MySql不支持設置時會報異常:

總結

本節通過Dapper對MySql中事務的四種隔離級別下進行測試,并且指出事務之間的相互關系和問題以供大家參考。

1、事務1隔離級別為ReadUncommitted時,可以讀取其它任何事務隔離級別下未提交的數據

2、事務1隔離級別為ReadCommitted時,不可以讀取其它事務未提交的數據,但是允許其它事務對數據表進行查詢、添加、修改和刪除;并且可以將其它事務增刪改重新獲取出來。

3、事務1隔離級別為RepeatableRead時,不可以讀取其它事務未提交的數據,但是允許其它事務對數據表進行查詢、添加、修改和刪除;但是其它事務的增刪改不影響事務1的查詢結果

4、事務1隔離級別為Serializable時,對其它事務對數據庫的修改(增刪改)強制串行處理。


臟讀重復讀幻讀
Read uncommitted
Read committed不會
Repeatable read不會不會
Serializable不會不會不會


原文地址:http://www.cnblogs.com/vipyoumay/p/8134434.html


.NET社區新聞,深度好文,歡迎訪問公眾號文章匯總 http://www.csharpkit.com


總結

以上是生活随笔為你收集整理的Net Core中数据库事务隔离详解——以Dapper和Mysql为例的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久久久久免费毛片精品 | 欧美一区免费观看 | 久久99精品久久久久久久久久久久 | www.91av在线| 久久精品综合视频 | 激情黄色一级片 | 六月婷婷色 | 在线观看深夜视频 | 手机在线欧美 | 欧日韩在线视频 | 国产精品手机在线观看 | 国产免费xvideos视频入口 | 伊人久久在线观看 | 欧美日韩精品在线 | 韩国三级在线一区 | 丝袜网站在线观看 | 久久av中文字幕片 | 贫乳av女优大全 | 性色av免费看| 日韩最新av在线 | 中文字幕日韩电影 | 久草av在线播放 | 日日天天 | 欧美日韩中文国产一区发布 | 久久久黄色免费网站 | 黄色三级免费网址 | 国产在线a免费观看 | 人人网av| 五月婷婷网站 | 蜜臀一区二区三区精品免费视频 | 91精品国产成 | 亚洲第一av在线播放 | 日韩大片在线看 | 欧美analxxxx | 久久免费黄色 | 亚洲 欧洲 国产 精品 | 日韩av免费网站 | 免费视频你懂得 | 国产在线不卡 | 精品专区| 99情趣网视频 | 免费在线播放视频 | 久久天堂亚洲 | 中文字幕久久精品一区 | 一本一道波多野毛片中文在线 | www.日日操.com| 人人超在线公开视频 | 麻豆精品视频在线观看免费 | 国产我不卡 | 日本久草电影 | 国产黄色免费在线观看 | 久久永久免费视频 | av怡红院 | 美女国产精品 | 91在线观| 天天操天天舔天天干 | 97品白浆高清久久久久久 | 久久系列 | 亚洲欧美婷婷六月色综合 | 国产三级在线播放 | 少妇资源站 | 99精品视频精品精品视频 | 欧美日韩视频在线观看免费 | 99国产精品久久久久老师 | 中文区中文字幕免费看 | 国产精品第一页在线 | 美女视频网站久久 | 午夜精品久久久久久久99无限制 | 婷婷激情综合五月天 | 亚洲精品合集 | 久久国产精品一国产精品 | 天天操天天干天天操天天干 | 成年人看片网站 | 激情中文在线 | 日韩电影精品一区 | 欧美精品做受xxx性少妇 | 一区二区三区日韩视频在线观看 | 粉嫩av一区二区三区四区在线观看 | 欧美日韩国产一区二区在线观看 | 国产一区二区在线精品 | 久久精品一区二区国产 | 香蕉久久久久久久 | 天天色天天操综合网 | 黄色三级在线观看 | 精品久久久久久久久中文字幕 | 久久视频免费观看 | 久久精品视频在线 | 精品一区二区视频 | 国产精品毛片一区二区 | 天天艹天天 | 在线播放 日韩专区 | 91精品国产91久久久久 | 中文字幕高清视频 | 视频在线观看国产 | 人人射人人爱 | 九九热在线精品 | 久久久久国产精品免费网站 | 亚洲精品美女在线观看播放 | 在线播放日韩av | 国产精品99精品 | 久久99这里只有精品 | 国产成人久久av977小说 | 免费观看xxxx9999片 | 婷婷视频在线观看 | 麻豆精品视频在线观看免费 | 天天天干夜夜夜操 | 国产小视频在线免费观看视频 | 免费视频久久久久 | 欧美日韩久 | 色偷偷网站视频 | 久久视精品 | 色婷婷综合成人av | 国产精品久久中文字幕 | 中文字幕韩在线第一页 | 国产视频网站在线观看 | 五月宗合网 | 中文字幕欲求不满 | 国产区在线看 | 91精品视频观看 | 狠狠成人 | 国产99久久久久 | 久久精品视 | 在线视频 区| 激情综合网天天干 | 欧洲一区精品 | 久久免费试看 | 亚洲综合色视频在线观看 | 在线91精品 | 最新国产精品亚洲 | 色妞色视频一区二区三区四区 | 婷婷精品视频 | 欧美激情精品久久久久久免费印度 | 国产成人精品一区一区一区 | 天天想夜夜操 | 久久久免费 | 一区二区三区四区在线 | 黄色av电影在线观看 | 在线视频亚洲 | 久久久久久久精 | 人人爽人人爽人人爽人人爽 | 久久99精品国产麻豆婷婷 | 天天干天天干天天 | 日韩在线网址 | 久久综合婷婷综合 | 日韩激情av在线 | 五月婷婷免费 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 久久久精品国产一区二区电影四季 | 最近日本字幕mv免费观看在线 | 欧美精彩视频在线观看 | 久久国产热 | 免费看高清毛片 | www日韩在线观看 | 黄色的网站在线 | 久久精品久久99 | 超级碰视频 | 国产最顶级的黄色片在线免费观看 | 99视频精品全部免费 在线 | 91免费黄视频 | 欧美小视频在线 | 日韩一区二区三区在线观看 | 国产传媒一区在线 | 91在线在线观看 | 91完整版 | 97电影网手机版 | 午夜精品视频在线 | av先锋影音少妇 | 成人高清av在线 | 精品在线播放视频 | 国产 一区二区三区 在线 | 在线观看蜜桃视频 | 久艹在线播放 | 天天操比| 国产又黄又硬又爽 | 91成人在线视频 | 一区二区三区免费看 | 91色一区二区三区 | 911香蕉视频| 最近2019年日本中文免费字幕 | 欧美日韩免费视频 | 日韩久久精品 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | av一级一片| 欧美va日韩va | 国产三级视频在线 | 江苏妇搡bbbb搡bbbb | 操操操日日日干干干 | 99视频免费观看 | www黄免费 | 国产精彩视频一区 | 久久免费视频这里只有精品 | 天天躁日日躁狠狠躁av麻豆 | 午夜av电影院 | 久久久久久久久久福利 | 亚洲蜜桃在线 | 麻豆高清免费国产一区 | 国产精品嫩草影院123 | 日韩免费观看一区二区 | 久久人人爽人人爽人人 | 久久影院中文字幕 | 深爱激情综合 | 91伊人久久大香线蕉蜜芽人口 | 国产精品三级视频 | 中文字幕日本电影 | 久久免费视频在线观看 | 欧美日韩国产高清视频 | 亚洲视频播放 | 97电影院在线观看 | 国产高清免费视频 | 色视频在线观看 | 亚洲电影图片小说 | 大胆欧美gogo免费视频一二区 | 久久精品福利 | 91av九色| 成人在线观看资源 | 日韩久久一区 | 2021国产精品| 日韩免费在线观看视频 | 在线看欧美 | 日韩国产精品一区 | 亚洲一区二区91 | 亚洲精品在线看 | 日韩免费看的电影 | 久久婷亚洲五月一区天天躁 | 国产精品视频最多的网站 | 精品国产成人 | 国产精成人品免费观看 | 99re国产| 欧美黄色高清 | 韩国在线一区二区 | 夜夜嗨av色一区二区不卡 | 91欧美国产 | 久久福利影视 | 精品久久一区二区三区 | 欧美精品免费在线 | 亚洲最新av在线 | 亚洲日本精品视频 | 亚洲五月六月 | 人人干人人上 | 五月丁香 | 九九热免费在线观看 | 青青五月天 | 国产精品福利视频 | 亚洲污视频| 国产人成一区二区三区影院 | 国产高清精品在线观看 | 久久久久免费电影 | 美女免费电影 | 亚洲成人欧美 | 国产成人精品福利 | 国产精品一区二区吃奶在线观看 | 天天综合网~永久入口 | 一区二区三区高清在线观看 | 五月婷婷激情综合网 | 91成人免费 | 色综合www| 国产精品h在线观看 | 欧美日韩一级久久久久久免费看 | 中文字幕av最新 | 亚洲人成免费网站 | 高清一区二区 | 日韩av在线资源 | 国产亚洲精品久久久久久久久久久久 | 中文字幕视频一区 | 婷婷久操 | 成人高清在线观看 | 亚洲精品动漫在线 | 久久久久亚洲国产 | 成人免费中文字幕 | 中文字幕av全部资源www中文字幕在线观看 | 久久久久久久久久久久av | 久久刺激视频 | 欧美视频www | 国产原厂视频在线观看 | 五月婷婷av | 国产丝袜美腿在线 | 日日爱夜夜爱 | 久久免费公开视频 | 欧美精品一区二区性色 | 久爱精品在线 | 精品亚洲网 | 五月天婷亚洲天综合网鲁鲁鲁 | 青青啪| 九九精品久久 | 大胆欧美gogo免费视频一二区 | 免费福利视频网站 | 国产在线观看高清视频 | 天天干天天爽 | 97国产超碰在线 | 久久精品久久精品久久精品 | 在线观看中文字幕av | 婷婷激情久久 | 久久这里 | 狠狠干婷婷 | 久久久国产一区二区三区 | 男女激情麻豆 | 伊人永久| 精品国偷自产在线 | 欧美九九九 | 美国人与动物xxxx | 国产爽视频 | 一区二区不卡高清 | 福利一区在线 | 精品国产成人在线影院 | 国产免码va在线观看免费 | 精品理论片 | 亚洲精品91天天久久人人 | 91亚洲精品久久久 | 免费看av片网站 | 一区二区电影在线观看 | 91精品办公室少妇高潮对白 | 久久久精品电影 | 久久激情视频 久久 | 日韩欧美一区二区在线观看 | 色五月色开心色婷婷色丁香 | 日本韩国精品一区二区在线观看 | 国产视频一| 在线播放精品一区二区三区 | 国产 日韩 在线 亚洲 字幕 中文 | 97超碰伊人 | 成人午夜精品 | 免费黄色网止 | 91成熟丰满女人少妇 | 色网址99 | 国产手机在线视频 | 人人玩人人添人人澡超碰 | 97色在线观看 | 日本大尺码专区mv | 色婷av| 精品久久久久久电影 | 中文字幕a∨在线乱码免费看 | 国产中文字幕在线播放 | 中文字幕在线观看你懂的 | 精品九九九 | 97精品国产一二三产区 | 精品国产一二三 | 人人澡超碰碰 | 久久er99热精品一区二区三区 | 久久婷婷开心 | 五月天,com | 91亚洲精品国偷拍自产在线观看 | 国产在线观看一 | 日韩性网站 | 国产精品99久久久久久武松影视 | 黄色大片av | 精品久久精品久久 | 97超碰人人 | 国产视频 亚洲精品 | 亚洲国产精品人久久电影 | 欧美大片第1页 | 亚洲免费在线视频 | 在线国产片 | 亚洲三区在线 | www.玖玖玖| 五月天婷婷综合 | 国产一级片在线播放 | 欧美日韩中文视频 | 88av网站 | 欧美精品免费视频 | 欧美激情视频在线免费观看 | 国产成人精品电影久久久 | 亚洲成人免费 | 成年人在线免费看视频 | 亚洲老妇xxxxxx| av综合网址| 激情影音先锋 | 在线免费国产 | 久久亚洲热| 在线观看国产亚洲 | 在线观看的a站 | avove黑丝| 一级片免费观看视频 | 在线视频欧美亚洲 | 色丁香综合 | 黄色毛片电影 | 国产字幕av | 亚洲午夜不卡 | 亚洲精品国产精品乱码不99热 | 亚洲精品动漫在线 | www.av在线播放| 一区二区三区免费在线观看视频 | 特级黄色视频毛片 | 精品国产一区二区三区久久 | 国产又粗又猛又色又黄网站 | 成人99免费视频 | 日韩电影一区二区在线观看 | 久久在线免费 | 一区二区三区久久 | 国产成人精品不卡 | 国产最新视频在线观看 | 69绿帽绿奴3pvideos | 女人18毛片a级毛片一区二区 | 黄色影院在线免费观看 | 国产综合视频在线观看 | 久久夜色网| 国产经典 欧美精品 | 国产精品亚洲精品 | 51久久夜色精品国产麻豆 | 91亚洲精品久久久蜜桃 | 国产视频97| 91爱爱视频 | 久久免费毛片 | 久久久久亚洲精品 | 西西444www大胆无视频 | 国产在线高清 | 久久久免费在线观看 | 高清在线一区 | 三级黄色免费 | 激情九九| 国产视频日韩视频欧美视频 | 最近中文字幕国语免费av | 嫩草伊人久久精品少妇av | 日韩美女黄色片 | 天天亚洲综合 | 日韩电影在线视频 | 日韩精品久久久久久久电影99爱 | 亚洲国产精品久久久久久 | 精品国产一区二区三区四区vr | 51久久成人国产精品麻豆 | 国产精品美女久久久久久免费 | 日韩精品免费一区二区 | 五月天亚洲精品 | 人人爽人人爽人人爽学生一级 | 国产一区二区不卡视频 | 久久精品a | 99视频99 | 超碰97国产在线 | 日韩av一区二区三区在线观看 | jizzjizzjizz亚洲 | 91视频高清 | www狠狠操 | 精品高清视频 | 天天操天天摸天天射 | 久久不卡国产精品一区二区 | 最新久久免费视频 | 午夜久草 | 99视频在线精品国自产拍免费观看 | 国产精品一区免费在线观看 | 欧美一区三区四区 | 天天色天天上天天操 | 国产成人在线播放 | 天天色天天干天天色 | 国产亚洲激情视频在线 | 欧美一区三区四区 | 国模视频一区二区三区 | 91精品成人 | 日韩精品在线免费观看 | 日日夜夜中文字幕 | 国产亚洲精品久久久久5区 成人h电影在线观看 | 亚洲精品国产精品乱码不99热 | 中文字幕影片免费在线观看 | 久草精品在线 | 欧美一级乱黄 | 五月天免费网站 | av福利第一导航 | 天天操天天操天天操天天操天天操天天操 | 国产一区高清在线 | 天天干天天干天天操 | 国内久久看 | 久久成人国产精品入口 | 成人av在线播放网站 | 免费观看第二部31集 | av在线网站观看 | www久久99| 日韩免费观看高清 | av电影免费在线播放 | 日韩有码在线播放 | 久久久午夜精品理论片中文字幕 | 国产精品乱码一区二三区 | 免费高清在线视频一区· | 精品久久五月天 | 视频在线精品 | 久久电影色 | 黄色特一级 | 色在线免费观看 | 91在线观看视频网站 | 国产精品午夜av | 国产成人av免费在线观看 | 中文字幕传媒 | 国产成人在线观看 | 色网站视频 | 人人玩人人添人人澡超碰 | 狠狠色丁香婷婷综合久小说久 | 免费福利片| 日韩国产欧美视频 | 97小视频| 91精品一区二区三区蜜臀 | 色播五月激情五月 | av片子在线观看 | 午夜精品一区二区三区可下载 | 久久久网址 | av五月婷婷 | 亚洲成人欧美 | 91综合久久一区二区 | 欧美国产日韩一区 | 日本精品一区二区在线观看 | 国内精品久久久久久久久久久久 | 麻豆一区在线观看 | 国产精品一区欧美 | 97免费公开视频 | 欧美aaaxxxx做受视频 | 日本中文一区二区 | 欧美综合在线视频 | 色婷婷啪啪免费在线电影观看 | 日韩午夜在线 | 亚洲狠狠婷婷 | 午夜在线观看一区 | 亚洲精品午夜久久久 | 日韩视频二区 | 麻豆系列在线观看 | 91av在线免费 | 日韩午夜小视频 | 免费福利片 | 国产精品99久久免费观看 | 毛片视频电影 | 婷婷天天色 | 日韩乱理| 国产啊v在线观看 | 婷婷香蕉 | 免费精品视频 | 综合网成人 | 日韩最新在线 | 免费高清在线观看成人 | 毛片1000部免费看 | 一区二区三区久久精品 | 久久成年视频 | 少妇搡bbbb搡bbb搡aa | 中文字幕在线观看免费 | 天天射天天射 | 久久伊人精品一区二区三区 | 国产精品久久久久久吹潮天美传媒 | 免费www视频 | 91免费网址 | 天天干,夜夜爽 | 色悠悠久久综合 | 国产黄色大片 | 欧美色图88 | 国产一区二区三区免费观看视频 | 日韩资源视频 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 亚洲高清激情 | 看毛片网站| 色噜噜狠狠狠狠色综合久不 | av日韩不卡 | 狠狠色丁香婷婷综合 | 超碰97久久 | 天天曰天天 | 亚洲国产成人在线观看 | 在线免费观看欧美日韩 | 天天干天天操天天入 | 免费黄色网止 | 丁香婷婷综合激情五月色 | 波多野结衣电影一区 | 国产精品av一区二区 | 精品视频不卡 | 成人黄色在线视频 | 在线免费色视频 | 国产伦精品一区二区三区免费 | 中字幕视频在线永久在线观看免费 | 久久久久久看片 | 999视频在线播放 | 国产精品每日更新 | 黄色特级毛片 | 精品毛片久久久久久 | 久久99久久99精品免视看婷婷 | 天天草天天 | av看片在线 | 91在线看 | 日韩欧美一区二区在线观看 | 五月天国产 | 国产69久久久 | 在线观看视频福利 | 日本不卡视频 | 九九av| 中文字幕av最新 | 天天操夜操视频 | 国产亚洲成av片在线观看 | 一区二区三区四区免费视频 | 亚洲永久精品在线观看 | 亚洲乱亚洲乱亚洲 | 97人人模人人爽人人喊网 | 国产69精品久久99不卡的观看体验 | 久久久久久久国产精品影院 | 日韩视频在线播放 | 在线一二三区 | 亚洲视频在线免费看 | 国产精品v欧美精品v日韩 | 超碰在线公开 | 久热香蕉视频 | 日韩大片在线免费观看 | 在线免费观看视频 | 成人免费视频免费观看 | 超碰97在线看 | 国产日韩在线播放 | 天天爱av导航 | 91精品一区国产高清在线gif | 超碰人人做 | 91视频免费看 | 91精品影视 | 久久久精品网站 | www.天天色.com | 欧美十八 | 91精品天码美女少妇 | 国产精品黑丝在线观看 | 亚洲三级精品 | 亚洲欧美激情精品一区二区 | 国产一二三区在线观看 | 精品国产免费观看 | 午夜色性片 | 激情综合网天天干 | 国产成人性色生活片 | 区一区二区三区中文字幕 | 国产精品入口a级 | 一级黄色片在线观看 | 成人三级黄色 | 最新av观看 | 性日韩欧美在线视频 | 亚洲精品午夜国产va久久成人 | 久久综合中文色婷婷 | 亚洲综合在线五月 | 91成人免费视频 | 日韩美视频| 97成人啪啪网 | 很黄很污的视频网站 | 狠狠色丁香久久婷婷综合丁香 | 亚洲国产中文在线 | 最近中文国产在线视频 | 在线免费观看国产 | 国产在线观看一 | 亚洲九九九在线观看 | 国产精品中文 | 男女视频国产 | 久久久国产在线视频 | 国产午夜三级一区二区三 | 99热在线这里只有精品 | www一起操| 中文字幕一区二区三区四区久久 | 久久精品导航 | 久久久亚洲国产精品麻豆综合天堂 | 亚洲人成综合 | 日本在线成人 | 免费日韩精品 | 久久成人福利 | 亚洲人片在线观看 | 天天干天天操天天操 | 日日操网站 | 久久99精品久久久久蜜臀 | 国产精品扒开做爽爽的视频 | 国产午夜精品久久 | 最近日本韩国中文字幕 | 人人干干人人 | 99国产精品久久久久久久久久 | 日韩久久久久 | 99精品乱码国产在线观看 | 在线观看成年人 | 在线免费国产视频 | 337p日本欧洲亚洲大胆裸体艺术 | 美女黄视频免费 | 97成人资源站 | 69av网| 久久国产二区 | 天天爱天天 | 国产香蕉97碰碰久久人人 | 国产高清视频在线播放 | 国产免费午夜 | 中文字幕一区在线观看视频 | 亚洲成人在线免费 | 国产精品免费观看国产网曝瓜 | 9色在线视频 | 69视频网站 | 中文字幕在线播放第一页 | 九七人人干 | 日韩精品免费一区二区在线观看 | 亚洲精品男女 | 亚洲免费激情 | 综合色站导航 | 久久黄色免费 | 91丨九色丨丝袜 | 91高清免费在线观看 | 99久久99热这里只有精品 | 97免费在线观看视频 | 999国产| 丰满少妇高潮在线观看 | 亚洲三级毛片 | 国产精品久久久久久久久久妇女 | 欧美日韩在线视频一区二区 | 国产精品入口a级 | 亚洲精品激情 | 人人看黄色| 99久热在线精品视频观看 | 激情五月伊人 | 69xx视频| 久久99欧美 | 在线成人一区二区 | 久久精品三级 | 婷婷香蕉 | 久久黄色影院 | 日韩高清毛片 | 精品国产黄色片 | 成人动漫精品一区二区 | 成人午夜电影网站 | 久久久综合九色合综国产精品 | 亚洲国内在线 | 99精品欧美一区二区蜜桃免费 | 91中文在线观看 | 国产99久久久国产精品免费看 | 色欧美日韩| 黄色一级网 | 久久精品视频中文字幕 | 九九热久久免费视频 | 视频精品一区二区三区 | 久久精品一区二区三区视频 | 日韩精品一区二区在线观看 | 久草在线资源观看 | 国产专区第一页 | 91最新国产 | av在线网站免费观看 | 亚洲精品视频网站在线观看 | 色丁香色婷婷 | 九九热在线免费观看 | 亚洲视频播放 | 久久精品一级片 | 国产日产精品一区二区三区四区 | 欧美日韩首页 | 亚洲欧美日韩一区二区三区在线观看 | ww视频在线观看 | 天天插狠狠插 | 久久婷婷影视 | 国产精品自在线拍国产 | 99热国产在线观看 | 久久久69| 久久精品综合 | 精品网站999www| 欧美性大战 | 69夜色精品国产69乱 | 亚洲美女免费精品视频在线观看 | 国产精品av在线免费观看 | 波多野结依在线观看 | 久久99免费 | 亚洲九九九在线观看 | 青青河边草免费直播 | www久| 日韩高清免费无专码区 | 波多野结衣综合网 | 久久国产精品免费观看 | 黄色aaa毛片| 精品国产一区二区三区av性色 | 亚洲1级片 | 狠狠操狠狠干天天操 | 91精品久久久久久久91蜜桃 | 午夜电影 电影 | 在线观看aa| 久久久久久久久久影视 | 黄色大片日本 | avove黑丝| 人人插人人干 | 国产97色| 国产在线观看免费观看 | 色综合久久88色综合天天人守婷 | 精品一区二区亚洲 | 人人干人人上 | 国产精品嫩草69影院 | 欧美天天干 | 成人福利av | 狠狠狠色丁香综合久久天下网 | 亚洲精品白浆高清久久久久久 | 日本女人的性生活视频 | 欧美无极色 | 精品欧美一区二区精品久久 | 在线天堂中文在线资源网 | 亚洲最新视频在线播放 | 亚洲国产资源 | 久草免费在线观看视频 | 国产成人av免费在线观看 | av再线观看 | 日韩在线精品一区 | 97品白浆高清久久久久久 | 日韩免费在线观看视频 | 波多野结衣一区二区 | 中文字幕高清在线播放 | 黄色在线小网站 | 青青河边草观看完整版高清 | 国产丝袜| 亚洲精品在线观看免费 | 九九久久影视 | 黄网在线免费观看 | 黄色成人在线 | 91精品视频在线免费观看 | 国产在线精品观看 | 国产一二三在线视频 | 亚洲精品在线观看视频 | 五月天电影免费在线观看一区 | 日韩精品不卡在线观看 | 欧美成人精品欧美一级乱黄 | 91人人射 | 亚洲综合最新在线 | 91免费网站在线观看 | 91大神视频网站 | 开心婷婷色 | 最近中文字幕免费观看 | 五月婷婷色 | 西西4444www大胆无视频 | 91精品国产99久久久久久久 | 久久综合九色综合欧美狠狠 | 少妇av网 | 黄色高清视频在线观看 | a天堂中文在线 | 在线播放国产精品 | 亚洲精品456在线播放第一页 | 久久久久久久久久网站 | 久久激情综合 | 香蕉视频免费在线播放 | 中文字幕在线观看一区二区 | 国产成人精品久久久久 | 国产夫妻性生活自拍 | 成人天堂网 | 久久草草热国产精品直播 | 成人一级影视 | 91精品久久久久久久久久久久久 | 久久综合色8888 | 伊人五月天 | 国产手机av在线 | 免费在线视频一区二区 | 91传媒91久久久 | 国产96精品 | 最近免费中文字幕 | 亚洲最快最全在线视频 | 天天色成人| 日本黄色一级电影 | 超碰97av在线| 国产精品精品久久久 | 97超碰在线久草超碰在线观看 | 二区三区在线视频 | 香蕉视频18 | 性色av香蕉一区二区 | 国产在线色站 | 国产精品mm | 免费国产在线观看 | 成人在线视频免费看 | 性日韩欧美在线视频 | 国内精品久久久久久久影视麻豆 | 国产视频一区在线免费观看 | 久久久www成人免费精品 | 国产精品麻豆99久久久久久 | 国产亚洲精品免费 | 精品播放 | 天堂中文在线播放 | 成人h动漫在线看 | 草久热| 国产精品自产拍在线观看网站 | 91中文在线 | 精品久久久久久亚洲 | 亚洲 欧洲av | 国产1区2 | 日韩在线国产 | 91在线免费视频 | 欧美a级在线 | 精品免费视频 | 久久精品国产亚洲 | 天天综合久久综合 | 亚州中文av | 91精品国产麻豆 | 久久网站最新地址 | 91视频在线自拍 | 少妇bbb | 中国一级片视频 | 中文字幕在线久一本久 | 国产精品久久久免费 | 最新av在线网站 | 日韩高清无线码2023 | 狠狠色综合网站久久久久久久 | 91色在线观看 | 国产日本在线观看 | 成人蜜桃网 | 激情久久久久久久久久久久久久久久 | 成人精品在线 | 国产免费亚洲 | 国语精品久久 | 日韩中出在线 | 97视频在线播放 | 免费日韩 精品中文字幕视频在线 | 国产精品久久久久久久久久免费 | 久久电影中文字幕视频 | av天天在线观看 | 91网在线观看 | 五月婷婷丁香网 | 黄色软件大全网站 | 久久久高清视频 | 69中文字幕 | 男女精品久久 | 亚洲永久字幕 | 精品国产乱码久久久久久三级人 | 成人在线电影观看 | 日韩免费av片 | 西西www4444大胆视频 | 欧美aa在线| 久久97久久97精品免视看 | 久久久999免费视频 日韩网站在线 | 久久麻豆视频 | 三级av片| 国产精品1区2区3区在线观看 | 国产精品免费人成网站 | 国产男女无遮挡猛进猛出在线观看 | 国产人成一区二区三区影院 | 99久久精品久久久久久动态片 | 久久久久久久国产精品视频 | 亚洲欧美在线视频免费 | 久久久亚洲电影 | 亚洲精品免费观看视频 | 欧美日韩中文字幕综合视频 | 韩日精品在线 | 亚洲精品毛片一级91精品 | 欧美日韩中文视频 | 国产字幕在线观看 | 黄色精品网站 | 日韩视频在线观看免费 | 超碰在线日韩 | 国产又粗又猛又色又黄网站 | 日韩一二三在线 | 精品播放| 国产美女视频免费观看的网站 | 伊人春色电影网 | 狠狠干夜夜操天天爽 | 超碰在线人人艹 | 狠狠干综合 | 国产精品久久久久永久免费 | 日韩精品免费在线播放 | 一区二区欧美在线观看 | 青青河边草观看完整版高清 | 国产亚洲精品久久久久久无几年桃 | 91成人短视频在线观看 | 日韩在线观看视频免费 | 操操操人人人 | 色一级片 | 九九热在线精品视频 | 97碰碰碰 | 9i看片成人免费看片 | 午夜性生活片 | 四虎成人精品在永久免费 | 91九色丨porny丨丰满6 | 91完整版在线观看 | 欧美日韩成人 | 国产精品视频你懂的 | 婷婷色网 | 黄色av观看 | 国产做a爱一级久久 | 伊人网av| 欧美日韩久久一区 | 婷婷综合在线 | 久久久91精品国产一区二区三区 | 日韩精品短视频 | 91麻豆精品国产91久久久久久久久 | www.超碰97.com| 日本精品一区二区在线观看 | 国产欧美精品xxxx另类 | 日韩高清免费观看 | 综合久久综合久久 | 69av久久| 狠狠狠干| 午夜国产一区二区 | 欧美ⅹxxxxxx| 欧美日韩性 | www.久久免费视频 | a在线免费 | 国产精品一区二区在线免费观看 | 久久免费影院 | 日韩大片免费在线观看 | 五月婷婷视频在线观看 | 日韩一级片观看 | 久久精品久久精品久久精品 | 成人动漫一区二区三区 | 九九爱免费视频在线观看 | 久久久五月天 | 激情五月色播五月 | 久草视频精品 | 亚洲小视频在线观看 | 色香蕉网 | 亚洲一二三区精品 | 五月天九九 | 91最新中文字幕 | 有码中文字幕在线观看 | 国产在线精品二区 | 精品不卡av| 日本资源中文字幕在线 | 99久久综合狠狠综合久久 | 99热官网| 久草视频免费在线观看 | 亚洲乱亚洲乱妇 | 最近2019年日本中文免费字幕 | 国产精品毛片久久久久久久 | 国产自制av| 成人资源网 | 天天综合网久久 | 久久国产精品视频 | 玖玖玖国产精品 | 伊人五月天av | 欧美日韩后 | 婷婷激情五月综合 |