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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

第二十二节: 以SQLServer为例介绍数据库自有的锁机制(共享锁、更新锁、排它锁等)和事务隔离级别 :

發布時間:2023/12/10 63 豆豆
生活随笔 收集整理的這篇文章主要介紹了 第二十二节: 以SQLServer为例介绍数据库自有的锁机制(共享锁、更新锁、排它锁等)和事务隔离级别 : 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一. 基本概念

1.共享鎖:(holdlock)

 (1). select的時候會自動加上共享鎖,該條語句執行完,共享鎖立即釋放,與事務是否提交沒有關系。

 (2). 顯式通過添加(holdlock)來顯式添加共享鎖(比如給select語句顯式添加共享鎖),當在事務里的時候,需要事務結束,該共享鎖才能釋放。

 (3). 同一資源,共享鎖和排它鎖不能共存,意味著update之前必須等資源上的共享鎖釋放后才能進行。

 (4). 共享鎖和共享鎖可以共存在一個資源上,意味著同一個資源允許多個線程同時進行select。

2. 排它鎖:(xlock)

 (1). update(或 insert 或 delete)的時候加自動加上排它鎖,該條語句執行完,排它鎖立即釋放,如果有事務的話,需要事務提交,該排它鎖才能釋放。

 (2). 顯式的通過添加(xlock)來顯式的添加排它鎖(比如給select語句顯式添加排它鎖),如果有事務的話,需要事務提交,該排它鎖才能釋放。

 (2). 同一資源,共享鎖和排它鎖不能共存,意味著update之前必須等資源上的共享鎖釋放后才能進行。

3. 更新鎖:(updlock)

 (1). 更新鎖只能顯式的通過(updlock)來添加,當在事務里的時候,需要事務結束,該更新鎖才能釋放。

 (2). 共享鎖和更新鎖可以同時在同一個資源上,即加了更新鎖,其他線程仍然可以進行select。

 (3).?更新鎖和更新鎖不能共存(同一時間同一資源上不能存在兩個更新鎖)。

 (4).?更新鎖和排它鎖不兼容

 (5). 利用更新鎖來解決死鎖問題,要比xlock性能高一些,因為加了updlock后,其他線程是可以進行select的。

4. 意向鎖

 意向鎖分為三種:意向共享 (IS)、意向排他 (IX) 和意向排他共享 (SIX)。?意向鎖可以提高性能,因為數據庫引擎僅在表級檢查意向鎖來確定事務是否可以安全地獲取該表上的鎖,而不需要檢查表中的每行或每頁上的鎖以確定事務是否可以鎖定整個表.

 T1:select * from table (xlock) where id=10

 T2:select * from table (tablock)?

分析:T1線程執行該語句時,會對該表id=10的這一行加排他鎖,同時會對整個表加上意向排它鎖(IX),當T2執行的時候,不需要逐條去檢查資源,只需要看到該表已經存在【意向排它鎖】,就直接等待。

PS: update table set xx=xx where id=1, 不光會對id=1的這條記錄加排它鎖,還會對整張表加意向排它鎖。

5. 計劃鎖(Schema Locks)

 用jdbc向數據庫發送了一條新的sql語句,數據庫要先對之進行編譯,在編譯期間,也會加鎖,稱之為:計劃鎖。

 編譯這條語句過程中,其它線程可以對表做任何操作(update、delete、加排他鎖等等),但不能做DDL(比如alter table)操作。

6. 鎖的顆粒:行鎖、頁鎖、表鎖

 (1). rowlock:行鎖---對每一行加鎖,然后釋放。(對某行加共享鎖)

 (2). paglock:頁鎖---1執行時,會先對第一頁加鎖,讀完第一頁后,釋放鎖,再對第二頁加鎖,依此類推。(對某頁加共享鎖)

  假設前10行記錄恰好是一頁(當然,一般不可能一頁只有10行記錄),那么T1執行到第一頁查詢時,并不會阻塞T2的更新。

 (3). tablock:表鎖---對整個表加鎖,然后釋放。?(對整張表加共享鎖)

注:

  1. 以上三種鎖執行完該語句后即可釋放,無須等待事務的提交,與事務是否提交沒有關系。

  2. 以上三種鎖劃分的角度不同,都是共享鎖,所以他們相互之間是可以共存的。

7. rowlock、paglock、tablock 和 holdlock的區別

 二者無非是劃分的角度不同,其實都是共享鎖,但在釋放上有所不同

 tablock(rowlock、paglock):對表、行、頁加共享鎖,只要語句執行完,就釋放,與事務是否提交沒關系。

 holdlock:對表加共享鎖,必須等著事務執行完,才能釋放。

8. tablockx對表加排它鎖,在有事務和沒事務的時候的區別

 (1). 無事務的時候:其他線程無法對該表進行讀和更新,除非加tablockx的語句執行完,才能進行。

 (2). 有事務的時候:必須整個事務執行了commit或rollback后才會釋放該排他鎖。

 xlock還可這么用:select * from table(xlock tablock) 效果等同于select * from table(tablockx)

9.各種鎖的兼容關系

  

二. 實戰測試

1. 測試共享鎖和共享鎖可以共存

1 {2 Console.WriteLine("測試共享鎖和共享鎖可以共存");3 Console.WriteLine("共享鎖select默認添加:1, 共享鎖(holdlock)顯式添加:2");4 string num = Console.ReadLine();5 if (num == "1")6 {7 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())8 using (var tx = db.Database.BeginTransaction())9 { 10 Console.WriteLine("開始查詢"); 11 //select的時候會加共享鎖 12 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor where id=2").FirstOrDefault(); 13 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 14 15 Console.WriteLine("按任意鍵進行事務提交"); 16 Console.ReadKey(); 17 try 18 { 19 tx.Commit(); 20 Console.WriteLine("事務提交成功"); 21 } 22 catch (Exception ex) 23 { 24 tx.Rollback(); 25 Console.WriteLine("事務提交失敗"); 26 Console.WriteLine(ex.Message); 27 } 28 } 29 } 30 else if (num == "2") 31 { 32 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 33 using (var tx = db.Database.BeginTransaction()) 34 { 35 Console.WriteLine("開始查詢"); 36 //顯式的通過holdlock添加 37 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor(holdlock) where id=2").FirstOrDefault(); 38 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 39 40 Console.WriteLine("按任意鍵進行事務提交"); 41 Console.ReadKey(); 42 try 43 { 44 tx.Commit(); 45 Console.WriteLine("事務提交成功"); 46 } 47 catch (Exception ex) 48 { 49 tx.Rollback(); 50 Console.WriteLine("事務提交失敗"); 51 Console.WriteLine(ex.Message); 52 } 53 } 54 } 55 }

結論:

  默認加 或者 顯式(holdlock)的方式加,都能共存。

2. 測試排它鎖和排它鎖不能共存

1 {2 Console.WriteLine("測試排它鎖和排它鎖不能共存");3 Console.WriteLine("排它鎖update默認添加:1, 排它鎖(xlock)顯式添加:2");4 string num = Console.ReadLine();5 if (num == "1")6 {7 Console.WriteLine("排它鎖業務");8 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())9 using (var tx = db.Database.BeginTransaction()) 10 { 11 Console.WriteLine("開始更新"); 12 //update的時候會自動加排它鎖 13 var result = db.Database.ExecuteSqlCommand("update OrderInfor set userName='lmr2' where id=2"); 14 Console.WriteLine("按任意鍵進行事務提交"); 15 Console.ReadKey(); 16 try 17 { 18 tx.Commit(); 19 Console.WriteLine("事務提交成功"); 20 } 21 catch (Exception ex) 22 { 23 tx.Rollback(); 24 Console.WriteLine("事務提交失敗"); 25 Console.WriteLine(ex.Message); 26 } 27 } 28 29 } 30 else if (num == "2") 31 { 32 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 33 using (var tx = db.Database.BeginTransaction()) 34 { 35 Console.WriteLine("開始查詢"); 36 //select的時候會對id=1的那行加上排它鎖,同時對整張表加上意向排它鎖,當別的線程查詢該表時,不用逐條去檢查資源 37 //只需要看到該表存在【意向排它鎖】,就會等待,無論查詢id等于幾,都會等待 38 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor (xlock) where id=1").FirstOrDefault(); 39 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 40 41 Console.WriteLine("按任意鍵進行事務提交"); 42 Console.ReadKey(); 43 try 44 { 45 tx.Commit(); 46 Console.WriteLine("事務提交成功"); 47 } 48 catch (Exception ex) 49 { 50 tx.Rollback(); 51 Console.WriteLine("事務提交失敗"); 52 Console.WriteLine(ex.Message); 53 } 54 } 55 } 56 57 }

結論:

  1. 關于排它鎖,無論是顯式(xlock)模式添加還是update默認加的模式,如果在事務里都需要事務提交才能釋放。

  2. 默認與默認、顯式與顯式、默認與顯式 這三種組合關系都不能共存,所以證明排它鎖和排它鎖之間不能共存。

  3. 注意:這里加排他鎖,會在表層次上加上意向排它鎖,與操作那條數據無關。

3. 測試共享鎖和排它鎖不能共存(顯式和隱式) (兩個結論未完成)

1 {2 Console.WriteLine("測試排它鎖和排它鎖不能共存");3 Console.WriteLine("默認select共享鎖:1, 顯式共享鎖(holdlock):2,默認update排它鎖:3,顯式排它鎖(xlock):4");4 string num = Console.ReadLine();5 6 if (num == "1")7 {8 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())9 using (var tx = db.Database.BeginTransaction())10 {11 Console.WriteLine("開始查詢");12 //select的時候會加共享鎖13 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor where id=2").FirstOrDefault();14 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}");15 16 Console.WriteLine("按任意鍵進行事務提交");17 Console.ReadKey();18 try19 {20 tx.Commit();21 Console.WriteLine("事務提交成功");22 }23 catch (Exception ex)24 {25 tx.Rollback();26 Console.WriteLine("事務提交失敗");27 Console.WriteLine(ex.Message);28 }29 }30 }31 else if (num == "2")32 {33 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())34 using (var tx = db.Database.BeginTransaction())35 {36 Console.WriteLine("開始查詢");37 //顯式的通過holdlock添加38 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor(holdlock) where id=2").FirstOrDefault();39 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}");40 41 Console.WriteLine("按任意鍵進行事務提交");42 Console.ReadKey();43 try44 {45 tx.Commit();46 Console.WriteLine("事務提交成功");47 }48 catch (Exception ex)49 {50 tx.Rollback();51 Console.WriteLine("事務提交失敗");52 Console.WriteLine(ex.Message);53 }54 }55 }56 else if (num == "3")57 {58 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())59 using (var tx = db.Database.BeginTransaction())60 {61 Console.WriteLine("開始更新");62 //update的時候會自動加排它鎖63 var result = db.Database.ExecuteSqlCommand("update OrderInfor set userName='lmr2' where id=2");64 Console.WriteLine("按任意鍵進行事務提交");65 Console.ReadKey();66 try67 {68 tx.Commit();69 Console.WriteLine("事務提交成功");70 }71 catch (Exception ex)72 {73 tx.Rollback();74 Console.WriteLine("事務提交失敗");75 Console.WriteLine(ex.Message);76 }77 }78 }79 else if (num == "4")80 {81 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())82 using (var tx = db.Database.BeginTransaction())83 {84 Console.WriteLine("開始查詢");85 //select的時候會對id=1的那行加上排它鎖,同時對整張表加上意向排它鎖,當別的線程查詢該表時,不用逐條去檢查資源86 //只需要看到該表存在【意向排它鎖】,就會等待,無論查詢id等于幾,都會等待87 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor (xlock) where id=1").FirstOrDefault();88 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}");89 90 Console.WriteLine("按任意鍵進行事務提交");91 Console.ReadKey();92 try93 {94 tx.Commit();95 Console.WriteLine("事務提交成功");96 }97 catch (Exception ex)98 {99 tx.Rollback(); 100 Console.WriteLine("事務提交失敗"); 101 Console.WriteLine(ex.Message); 102 } 103 } 104 } 105 106 107 }

結論:

  1.默認select共享鎖先執行,未提交事務的情況下,默認update排它鎖 和 顯式排它鎖(xlock)都能正常執行。,

  證明:默認共享鎖語句執行完立即釋放,與事務是否提交沒有關系

  2.顯式共享鎖(holdlock),未提交事務的情況下,默認update排它鎖 和 顯式排它鎖(xlock)都 不能 正常執行,

  證明:顯式共享鎖(holdlock)需要事務提交才能釋放,同時也證明共享鎖和排它鎖不能共存。

  3.默認update排它鎖先執行,未提交事務的情況下,默認select共享鎖能執行,顯式共享鎖(holdlock)不能執行。

  證明:

  4.顯式排它鎖(xlock)先執行,未提交事務的情況下,默認select共享鎖能執行,顯式共享鎖(holdlock)不能執行。

  證明:

4. 測試共享鎖、更新鎖、排它鎖間的關系

1 {2 Console.WriteLine("測試更新鎖、排它鎖、共享鎖間的關系");3 Console.WriteLine("更新鎖業務輸入:1, 排它鎖業務輸入:2,共享鎖輸入:3");4 string num = Console.ReadLine();5 if (num == "1")6 {7 Console.WriteLine("更新鎖業務");8 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())9 using (var tx = db.Database.BeginTransaction()) 10 { 11 Console.WriteLine("開始查詢"); 12 //顯式的添加更新鎖 13 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor(updlock) where id=2").FirstOrDefault(); 14 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 15 Console.WriteLine("按任意鍵進行事務提交"); 16 Console.ReadKey(); 17 try 18 { 19 tx.Commit(); 20 Console.WriteLine("事務提交成功"); 21 } 22 catch (Exception ex) 23 { 24 tx.Rollback(); 25 Console.WriteLine("事務提交失敗"); 26 Console.WriteLine(ex.Message); 27 } 28 } 29 } 30 else if (num == "2") 31 { 32 Console.WriteLine("排它鎖業務"); 33 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 34 using (var tx = db.Database.BeginTransaction()) 35 { 36 Console.WriteLine("開始更新"); 37 //update的時候會自動加排它鎖 38 var result = db.Database.ExecuteSqlCommand("update OrderInfor set userName='lmr2' where id=2"); 39 Console.WriteLine("按任意鍵進行事務提交"); 40 Console.ReadKey(); 41 try 42 { 43 tx.Commit(); 44 Console.WriteLine("事務提交成功"); 45 } 46 catch (Exception ex) 47 { 48 tx.Rollback(); 49 Console.WriteLine("事務提交失敗"); 50 Console.WriteLine(ex.Message); 51 } 52 } 53 } 54 else if (num == "3") 55 { 56 Console.WriteLine("共享鎖業務"); 57 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 58 using (var tx = db.Database.BeginTransaction()) 59 { 60 Console.WriteLine("開始查詢"); 61 //select的時候會自動加共享鎖 62 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor where id=2").FirstOrDefault(); 63 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 64 Console.WriteLine("按任意鍵進行事務提交"); 65 Console.ReadKey(); 66 try 67 { 68 tx.Commit(); 69 Console.WriteLine("事務提交成功"); 70 } 71 catch (Exception ex) 72 { 73 tx.Rollback(); 74 Console.WriteLine("事務提交失敗"); 75 Console.WriteLine(ex.Message); 76 } 77 } 78 } 79 }

結論:

  1. 更新鎖需要事務提交才能釋放。

  2. 更新鎖和更新鎖不能共存。

  3. 更新鎖和排它鎖不能共存。

  4. 更新鎖和共享鎖可以共存。

5. 測試表鎖和排它鎖不能共存

1 {2 Console.WriteLine("測試表鎖和排它鎖的問題");3 Console.WriteLine("表鎖業務輸入:1, 排它鎖業務輸入:2");4 string num = Console.ReadLine();5 if (num == "1")6 {7 Console.WriteLine("表鎖業務");8 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())9 using (var tx = db.Database.BeginTransaction()) 10 { 11 Console.WriteLine("開始查詢"); 12 13 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor(tablock) where id=2").FirstOrDefault(); 14 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 15 Console.WriteLine("按任意鍵進行事務提交"); 16 Console.ReadKey(); 17 try 18 { 19 tx.Commit(); 20 Console.WriteLine("事務提交成功"); 21 } 22 catch (Exception ex) 23 { 24 tx.Rollback(); 25 Console.WriteLine("事務提交失敗"); 26 Console.WriteLine(ex.Message); 27 } 28 } 29 } 30 else if (num == "2") 31 { 32 Console.WriteLine("排它鎖業務"); 33 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 34 using (var tx = db.Database.BeginTransaction()) 35 { 36 Console.WriteLine("開始更新"); 37 //update的時候會自動加排它鎖 38 var result = db.Database.ExecuteSqlCommand("update OrderInfor set userName='lmr2' where id=2"); 39 Console.WriteLine("按任意鍵進行事務提交"); 40 Console.ReadKey(); 41 try 42 { 43 tx.Commit(); 44 Console.WriteLine("事務提交成功"); 45 } 46 catch (Exception ex) 47 { 48 tx.Rollback(); 49 Console.WriteLine("事務提交失敗"); 50 Console.WriteLine(ex.Message); 51 } 52 } 53 } 54 }

?結論:

  1. 先執行表鎖,事務未提交的情況下,排它鎖能正常進行。

  證明:表鎖只要執行完該語句立即釋放,與事務是否提交沒有關系。

  2. 先執行默認排它鎖,事務未提交的情況想,表鎖不能運行。

  證明:默認的排它鎖必須等待事務提交完才能釋放,同時證明排它鎖和表鎖不能共存 (表鎖在這里的特點和共享鎖一樣,實質表鎖也就是個共享鎖,只是劃分的角度不同)

6. 測試行鎖和排它鎖不能共存

1 {2 Console.WriteLine("測試行鎖和排它鎖的問題");3 Console.WriteLine("行鎖業務輸入:1, 排它鎖業務輸入:2");4 string num = Console.ReadLine();5 if (num == "1")6 {7 Console.WriteLine("行鎖業務");8 using (LockDemoDBEntities1 db = new LockDemoDBEntities1())9 using (var tx = db.Database.BeginTransaction()) 10 { 11 Console.WriteLine("開始查詢"); 12 13 var orderInfor = db.Database.SqlQuery<OrderInfor>("select * from OrderInfor(rowlock) where id=2").FirstOrDefault(); 14 Console.WriteLine($"id為:{orderInfor.id},userName為:{orderInfor.userName},destination為:{orderInfor.destination}"); 15 Console.WriteLine("按任意鍵進行事務提交"); 16 Console.ReadKey(); 17 try 18 { 19 tx.Commit(); 20 Console.WriteLine("事務提交成功"); 21 } 22 catch (Exception ex) 23 { 24 tx.Rollback(); 25 Console.WriteLine("事務提交失敗"); 26 Console.WriteLine(ex.Message); 27 } 28 } 29 } 30 else if (num == "2") 31 { 32 Console.WriteLine("排它鎖業務"); 33 using (LockDemoDBEntities1 db = new LockDemoDBEntities1()) 34 using (var tx = db.Database.BeginTransaction()) 35 { 36 Console.WriteLine("開始更新"); 37 //update的時候會自動加排它鎖 38 var result = db.Database.ExecuteSqlCommand("update OrderInfor set userName='lmr2' where id=1"); 39 Console.WriteLine("按任意鍵進行事務提交"); 40 Console.ReadKey(); 41 try 42 { 43 tx.Commit(); 44 Console.WriteLine("事務提交成功"); 45 } 46 catch (Exception ex) 47 { 48 tx.Rollback(); 49 Console.WriteLine("事務提交失敗"); 50 Console.WriteLine(ex.Message); 51 } 52 } 53 } 54 }

結論:

  1. 先執行行鎖,事務未提交的情況下,排它鎖能正常進行。

  證明:行鎖只要執行完該語句立即釋放,與事務是否提交沒有關系。

  2. 先執行默認排它鎖,事務未提交的情況想,行鎖不能運行。

  證明:默認的排它鎖必須等待事務提交完才能釋放,同時證明排它鎖和行鎖不能共存 (行鎖在這里的特點和共享鎖一樣,實質表鎖也就是個共享鎖,只是劃分的角度不同)。

7. 測試頁鎖和排它鎖不能共存(與表鎖、行鎖類似,不單獨測試)

?

三. 事務隔離級別

1. 四種錯誤

 (1). 臟讀:第一個事務讀取第二個事務正在更新的數據,如果第二個事務還沒有更新完成,那么第一個事務讀取的數據將是一半為更新過的,一半還沒更新過的數據,這樣的數據毫無意義。

 (2). 幻讀:第一個事務讀取一個結果集后,第二個事務,對這個結果集進行“增刪”操作,然而第一個事務中再次對這個結果集進行查詢時,數據發現丟失或新增。

 (3).?更新丟失:多個用戶同時對一個數據資源進行更新,必定會產生被覆蓋的數據,造成數據讀寫異常。

 (4). 不可重復讀:如果一個用戶在一個事務中多次讀取一條數據,而另外一個用戶則同時更新啦這條數據,造成第一個用戶多次讀取數據不一致。

2. 死鎖

(1). 定義:相互等待對方釋放資源,造成資源讀寫擁擠堵塞的情況,就被稱為死鎖現象,也叫做阻塞。如下面的例子:

1 begin tran 2 select * from OrderInfor(holdlock) where id='333' 3 waitfor delay '0:0:8' --等待8秒執行下面的語句 4 update OrderInfor set userName='ypf1' where id='333' 5 commit tran

分析:線程T1 和 線程T2 同時執行該事務,假設線程T1先執行完select,線程T2隨后執行完select,線程T1要執行update語句的時候,根據數據庫策略需要將【共享鎖】提升為【排它鎖】才能執行,所以必須等線程T2上的【共享鎖】釋放,而線程T2需要事務提交完才能釋放鎖,同時T1的【共享鎖】不釋放導致T2要一直等待,這樣造成了T1和T2相互等待的局面,就是死鎖現象。

(2).?數據庫的默認處理思路的邏輯:

  數據庫并不會出現無限等待的情況,是因為數據庫搜索引擎會定期檢測這種狀況,一旦發現有情況,立馬【隨機】選擇一個事務作為犧牲品。犧牲的事務,將會回滾數據。有點像兩個人在過獨木橋,兩個無腦的人都走在啦獨木橋中間,如果不落水,必定要有一個人給退回來。這種相互等待的過程,是一種耗時耗資源的現象,所以能避則避。

(3). 手動控制鎖級別:

 語法:set deadlock_priority <級別>

 死鎖處理的優先級別為 low<normal<high,不指定的情況下默認為normal,犧牲品為隨機。如果指定,犧牲品為級別低的。

 還可以使用數字來處理標識級別:-10到-5為low,-5為normal,-5到10為high,數越小,級別越低,越先犧牲,越先回滾。

(4). 案例測試

  事先準備:?使用【LockDemoDB】中的OrderInfor表進行測試,?事先插入一條測試數據,之后都使用該數據進行測試。

1 insert into OrderInfor values('333','ypf','去青島','lmr','1')

  在兩個窗口里(即兩個線程)執行下面一段代碼:

1 -- 線程1執行下面語句2 begin tran3 begin try4 set deadlock_priority -95 select * from OrderInfor(holdlock) where id='333'6 waitfor delay '0:0:8' --等待8秒執行下面的語句7 update OrderInfor set userName='ypf1' where id='333'8 commit tran9 end try 10 begin catch 11 rollback tran 12 end catch

1 -- 線程2測試(下面語句單獨開一個窗口進行測試)2 begin tran3 begin try4 set deadlock_priority -85 select * from OrderInfor(holdlock) where id='333'6 waitfor delay '0:0:8' --等待8秒執行下面的語句7 update OrderInfor set userName='ypf2' where id='333'8 commit tran9 end try 10 begin catch 11 rollback tran 12 end catch

分析:線程1和線程2分別執行下面語句,產生死鎖,由于線程1設置的級別? -9 < -8,所以線程1犧牲且回滾,最后是線程2執行的結果,userName為ypf2? .

?(5). 擴展補充

?A.?查看鎖活動情況

1 select * from sys.dm_tran_locks

B. 查看事務活動情況

1 dbcc opentran

C.? 設置鎖的超時時間

1 set lock_timeout 4000

PS:

  ?發生死鎖的時候,數據庫引擎會自動檢測死鎖,解決問題,然而這樣子是很被動,只能在發生死鎖后,等待處理。然而我們也可以主動出擊,設置鎖超時時間,一旦資源被鎖定阻塞,超過設置的鎖定時間,阻塞語句自動取消,釋放資源,報1222錯誤。

  好東西一般都具有兩面性,調優的同時,也有他的不足之處,那就是一旦超過時間,語句取消,釋放資源,但是當前報錯事務,不會回滾,會造成數據錯誤,你需要在程序中捕獲1222錯誤,用程序處理當前事務的邏輯,使數據正確。為0時,即為一旦發現資源鎖定,立即報錯,不在等待,當前事務不回滾,設置時間需謹慎處理后事啊,你hold不住的。
拓展殺死鎖和進程

1 --檢測死鎖2 --如果發生死鎖了,我們怎么去檢測具體發生死鎖的是哪條SQL語句或存儲過程?3 --這時我們可以使用以下存儲過程來檢測,就可以查出引起死鎖的進程和SQL語句。SQL Server自帶的系統存儲過程sp_who和sp_lock也可以用來查找阻塞和死鎖, 但沒有這里介紹的方法好用。 4 5 use master6 go7 create procedure sp_who_lock8 as9 begin10 declare @spid int,@bl int,11 @intTransactionCountOnEntry int,12 @intRowcount int,13 @intCountProperties int,14 @intCounter int15 16 create table #tmp_lock_who (17 id int identity(1,1),18 spid smallint,19 bl smallint)20 21 IF @@ERROR<>0 RETURN @@ERROR22 23 insert into #tmp_lock_who(spid,bl) select 0 ,blocked24 from (select * from sysprocesses where blocked>0 ) a 25 where not exists(select * from (select * from sysprocesses where blocked>0 ) b 26 where a.blocked=spid)27 union select spid,blocked from sysprocesses where blocked>028 29 IF @@ERROR<>0 RETURN @@ERROR 30 31 -- 找到臨時表的記錄數32 select @intCountProperties = Count(*),@intCounter = 133 from #tmp_lock_who34 35 IF @@ERROR<>0 RETURN @@ERROR 36 37 if @intCountProperties=038 select '現在沒有阻塞和死鎖信息' as message39 40 -- 循環開始41 while @intCounter <= @intCountProperties42 begin43 -- 取第一條記錄44 select @spid = spid,@bl = bl45 from #tmp_lock_who where Id = @intCounter 46 begin47 if @spid =0 48 select '引起數據庫死鎖的是: '+ CAST(@bl AS VARCHAR(10)) + '進程號,其執行的SQL語法如下'49 else50 select '進程號SPID:'+ CAST(@spid AS VARCHAR(10))+ '被' + '進程號SPID:'+ CAST(@bl AS VARCHAR(10)) +'阻塞,其當前進程執行的SQL語法如下'51 DBCC INPUTBUFFER (@bl )52 end 53 54 -- 循環指針下移55 set @intCounter = @intCounter + 156 end57 58 drop table #tmp_lock_who59 60 return 061 end62 63 64 --殺死鎖和進程65 --如何去手動的殺死進程和鎖?最簡單的辦法,重新啟動服務。但是這里要介紹一個存儲過程,通過顯式的調用,可以殺死進程和鎖。66 67 use master68 go69 70 if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_killspid]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)71 drop procedure [dbo].[p_killspid]72 GO73 74 create proc p_killspid75 @dbname varchar(200) --要關閉進程的數據庫名76 as 77 declare @sql nvarchar(500) 78 declare @spid nvarchar(20)79 80 declare #tb cursor for81 select spid=cast(spid as varchar(20)) from master..sysprocesses where dbid=db_id(@dbname)82 open #tb83 fetch next from #tb into @spid84 while @@fetch_status=085 begin 86 exec('kill '+@spid)87 fetch next from #tb into @spid88 end 89 close #tb90 deallocate #tb91 go92 93 --用法 94 exec p_killspid 'newdbpy' 95 96 --查看鎖信息97 --如何查看系統中所有鎖的詳細信息?在企業管理管理器中,我們可以看到一些進程和鎖的信息,這里介紹另外一種方法。98 --查看鎖信息99 create table #t(req_spid int,obj_name sysname) 100 101 declare @s nvarchar(4000) 102 ,@rid int,@dbname sysname,@id int,@objname sysname 103 104 declare tb cursor for 105 select distinct req_spid,dbname=db_name(rsc_dbid),rsc_objid 106 from master..syslockinfo where rsc_type in(4,5) 107 open tb 108 fetch next from tb into @rid,@dbname,@id 109 while @@fetch_status=0 110 begin 111 set @s='select @objname=name from ['+@dbname+']..sysobjects where id=@id' 112 exec sp_executesql @s,N'@objname sysname out,@id int',@objname out,@id 113 insert into #t values(@rid,@objname) 114 fetch next from tb into @rid,@dbname,@id 115 end 116 close tb 117 deallocate tb 118 119 select 進程id=a.req_spid 120 ,數據庫=db_name(rsc_dbid) 121 ,類型=case rsc_type when 1 then 'NULL 資源(未使用)' 122 when 2 then '數據庫' 123 when 3 then '文件' 124 when 4 then '索引' 125 when 5 then '表' 126 when 6 then '頁' 127 when 7 then '鍵' 128 when 8 then '擴展盤區' 129 when 9 then 'RID(行 ID)' 130 when 10 then '應用程序' 131 end 132 ,對象id=rsc_objid 133 ,對象名=b.obj_name 134 ,rsc_indid 135 from master..syslockinfo a left join #t b on a.req_spid=b.req_spid 136 137 go 138 drop table #t

?3. 事務隔離級別

  read uncommitted:這個隔離級別最低啦,可以讀取到一個事務正在處理的數據,但事務還未提交,這種級別的讀取叫做臟讀。

  read committed:這個級別是默認選項,不能臟讀,不能讀取事務正在處理沒有提交的數據,但能修改。

  repeatable read:不能讀取事務正在處理的數據,也不能修改事務處理數據前的數據。

  snapshot:指定事務在開始的時候,就獲得了已經提交數據的快照,因此當前事務只能看到事務開始之前對數據所做的修改。

  serializable:最高事務隔離級別,只能看到事務處理之前的數據。?

?事先準備:?使用【LockDemoDB】中的OrderInfor表進行測試,?事先插入一條測試數據,之后都使用該數據進行測試。

線程1執行下面代碼:

1 begin tran 2 update OrderInfor set userName='ypf1' where id='333' 3 waitfor delay '0:0:8' --等待8秒執行下面的語句 4 rollback tran

?線程1執行后,開啟一個新線程(在一個新窗口)馬上執行下面代碼:

情況1

1 --1. 設置允許臟讀,能馬上讀出來數據 2 set tran isolation level read uncommitted 3 select * from OrderInfor where id='333' --讀取的數據為正在修改的數據 ,即為臟讀 4 5 --8秒之后數據已經回滾,查出來的數據是回滾后的數據 ypf 6 waitfor delay '0:0:8' 7 select * from OrderInfor where id='333'

情況2

1 --2. 設置不允許臟讀,不能馬上讀出來數據(數據庫默認就是這種模式) 2 set tran isolation level read committed 3 select * from OrderInfor where id='333' 4 5 6 --可以修改(但也得等線程1執行完事務后),8s后顯示的是 ypf2,而不是原回滾后的數據ypf 7 update OrderInfor set userName='ypf2' where id='333' 8 waitfor delay '0:0:8' 9 select * from OrderInfor where id='333'

其它三種暫不測試了,與此同樣道理進行測試。

?

?

?

?

總結

以上是生活随笔為你收集整理的第二十二节: 以SQLServer为例介绍数据库自有的锁机制(共享锁、更新锁、排它锁等)和事务隔离级别 :的全部內容,希望文章能夠幫你解決所遇到的問題。

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

久久久久久高潮国产精品视 | 久久麻豆精品 | 国产精品免费成人 | 狠狠躁夜夜躁人人爽超碰91 | 国产精品成人在线观看 | 国产精品岛国久久久久久久久红粉 | 99国内精品久久久久久久 | 热久在线 | 狠狠色狠狠色综合日日92 | 国产一二区视频 | 一级免费av | 久久在线免费观看视频 | 久久久久久久久久久高潮一区二区 | 日韩精品一区二区三区在线播放 | 国产精品国产三级国产aⅴ9色 | 国产一区二区三区高清播放 | 亚洲国产剧情av | 五月天亚洲综合 | 国产资源中文字幕 | 91九色蝌蚪国产 | 久久精品久久久久久久 | 五月天亚洲婷婷 | 波多野结衣视频一区二区三区 | 最新中文字幕 | 日本久久视频 | 一区在线电影 | 国产在线中文 | 97在线视频免费看 | 久久久国产精品网站 | 99热精品视| 99久久久国产精品免费99 | 日日夜夜爱| 久久精品首页 | 在线观看www91 | 天天插伊人 | 国产精品成人av久久 | 日韩网站中文字幕 | 一级国产视频 | 91中文字幕视频 | 色综合久久久 | 国产成人精品亚洲 | 国产精品igao视频网网址 | 免费看v片 | 欧美日韩精品在线播放 | 日韩激情网 | 毛片1000部免费看 | 国产麻豆成人传媒免费观看 | 激情综合色综合久久 | 97视频在线观看视频免费视频 | 麻豆免费观看视频 | 9在线观看免费高清完整 | 午夜美女av | 91自拍91| 69av国产| 人人插人人做 | 国产高清久久久久 | 国产一级不卡视频 | 丁香五月网久久综合 | 99热国内精品 | 久久电影日韩 | 国产精品夜夜夜一区二区三区尤 | 亚洲综合最新在线 | 成人一区二区三区在线 | 91精彩视频在线观看 | 91视频高清完整版 | 91亚洲国产| 色婷婷88av视频一二三区 | 国产正在播放 | 最新日韩精品 | 黄网站色视频 | 在线观看va| 日韩精选在线 | 成人h电影在线观看 | 欧美一级久久久久 | 亚洲h在线播放在线观看h | 国产精品久久久一区二区三区网站 | 日韩精品中文字幕在线不卡尤物 | 青青啪| 精品一区二区精品 | 日韩网站视频 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 欧美日韩久久一区 | 麻豆传媒在线免费看 | 久久久国产日韩 | 91丨九色丨国产丨porny精品 | 午夜精品麻豆 | 亚洲人成网站精品片在线观看 | 欧美日韩一区三区 | 精品国产乱码久久久久久天美 | 中文字幕在线第一页 | 美女久久视频 | 亚洲天天草 | 久久久国产精品久久久 | 国产高清在线永久 | 中文字幕免费看 | 久久伦理电影 | 麻豆一区二区三区视频 | 婷久久 | 亚洲欧洲在线视频 | 婷婷性综合 | 91亚瑟视频| 天天草天天爽 | 奇人奇案qvod| 激情 婷婷 | 欧美日韩免费观看一区=区三区 | 国产专区精品视频 | 亚洲观看黄色网 | 国产999视频在线观看 | 日日爱网站 | 最近av在线 | 高清免费av在线 | 国产视频不卡一区 | 91精品国产一区二区三区 | 9在线观看免费高清完整版在线观看明 | 在线观看免费视频你懂的 | av福利网址导航大全 | av在线观 | 四虎在线视频 | 中文字幕亚洲欧美日韩 | 日韩欧美精品一区二区三区经典 | 国产精品 日本 | 日日干精品| 日韩一级电影在线 | 精品福利在线视频 | 91福利视频网站 | 成人在线免费视频 | 五月天色网站 | 99精品久久99久久久久 | 在线欧美日韩 | 久久久久久美女 | 性色va| 亚洲视频99 | 偷拍精品一区二区三区 | 伊人色播| 黄色一级免费电影 | 天天射天天做 | 97精品超碰一区二区三区 | 国产一级高清视频 | 日本精品免费看 | 九色琪琪久久综合网天天 | 精品亚洲视频在线观看 | 99精品在线免费在线观看 | 亚洲精品欧洲精品 | 久久高清| 国产日产av | 人人干人人超 | 久爱综合| 亚洲国产福利视频 | 在线看国产视频 | mm1313亚洲精品国产 | 国产精品亚洲片夜色在线 | 91在线操| 在线免费看黄色 | 欧美色插| 日韩专区在线观看 | 97在线观看视频 | 国产精品久久久久久久婷婷 | 日韩av中文 | 国产精品久久久一区二区 | 天天天天色综合 | 欧美做受高潮1 | 久草干 | 91成人精品一区在线播放69 | 国产又粗又猛又爽又黄的视频免费 | 国产精品乱码高清在线看 | 我爱av激情网 | 成人国产精品久久久 | 伊人婷婷久久 | 日韩免 | 国产福利精品在线观看 | 亚洲视频456 | 亚洲经典精品 | 九九视频免费观看视频精品 | 中文字幕91 | 在线观看视频你懂 | 午夜精品一二三区 | 久久99精品国产99久久6尤 | 成人在线观看网址 | 国产精品123| 久久精品成人欧美大片古装 | 欧美日比视频 | 国产中文字幕大全 | 亚洲色图美腿丝袜 | 九九热中文字幕 | 91麻豆国产福利在线观看 | 久久96| 五月婷婷在线视频观看 | 国产午夜一区二区 | 在线观看国产亚洲 | 丝袜足交在线 | av 一区二区三区四区 | 黄色日批网站 | 亚洲成人av片在线观看 | 在线观看视频91 | 九九亚洲精品 | 国产精品99久久久久久小说 | 伊人成人激情 | 深爱婷婷激情 | 成人黄色资源 | 日韩免费一区二区在线观看 | 成年人在线看片 | 国产精品一区二区久久精品爱微奶 | 人人澡超碰碰97碰碰碰软件 | 欧美男同网站 | 91精品免费在线 | 在线看毛片网站 | 成人不用播放器 | 三级av网站 | 久久久久免费观看 | 麻豆视频免费入口 | 九热在线 | 亚洲欧美综合 | 亚洲网站在线 | 97超碰在| 久久这里只有精品9 | 在线观看片 | 亚洲国产成人在线观看 | 美女免费黄网站 | 久久久91精品国产一区二区三区 | 天天操狠狠操夜夜操 | 欧美精品免费视频 | 久久免费播放视频 | 免费欧美高清视频 | 国产精品视频永久免费播放 | 欧美一进一出抽搐大尺度视频 | 麻豆视频一区二区 | 亚洲婷婷综合色高清在线 | 亚洲高清在线视频 | 激情黄色av| 久亚洲| 高清美女视频 | 激情伊人| 中文国产成人精品久久一 | 亚洲精品18日本一区app | 欧美日韩在线免费视频 | 国内精品久久久久影院日本资源 | 日日夜夜91| 韩国av免费在线观看 | 亚洲天天干 | 在线观看免费高清视频大全追剧 | 亚洲视频在线视频 | 六月丁香婷 | 欧洲一区二区三区精品 | 久久精品毛片 | 最近免费中文视频 | 国产精品久久久久久久久久久久久 | 国产在线观看xxx | 天天操天天射天天爱 | 天天操天天干天天干 | 国产一级在线观看 | 91丨九色丨蝌蚪丨老版 | 天天草天天草 | 国产一区二区在线精品 | 亚洲一区不卡视频 | 成人av网站在线观看 | 精品国模一区二区 | 在线观看视频色 | 在线免费观看黄色 | 久久在现| 综合久久久久 | 人人插人人插 | 亚洲综合日韩在线 | 久草免费看 | 精品一区二区三区久久久 | 国产免费又粗又猛又爽 | 在线观看国产日韩 | 天天草夜夜| 日韩在线视频免费看 | 亚洲精品免费在线视频 | 久草精品资源 | 色a综合 | 国产精品欧美久久久久天天影视 | 精品国偷自产国产一区 | 日韩最新在线 | 色综合久久综合网 | 在线你懂| 最新国产一区二区三区 | 97视频在线免费播放 | 亚洲国产精品va在线看黑人 | 国产视频亚洲视频 | www.99热精品| h动漫中文字幕 | 欧美aaa一级 | 国产精品久久久久久久久久直播 | 成人小视频在线 | 色综合天天天天做夜夜夜夜做 | av软件在线观看 | 国产不卡一二三区 | 欧洲在线免费视频 | 99热这里有精品 | 操久| 美女黄频在线观看 | 精品中文字幕在线观看 | 激情综合色播五月 | 人人看人人草 | 天天草av | 亚洲天堂香蕉 | 日韩视频1区 | 国产手机在线精品 | 日韩一区在线播放 | 美女视频久久黄 | 一级黄色免费网站 | 中文字幕在线不卡国产视频 | 久久视频免费在线 | 亚洲国产精品资源 | 久草精品在线播放 | 国产 一区二区三区 在线 | 精品亚洲成人 | 99久久精品免费看国产四区 | 黄网站免费久久 | 中文字幕文字幕一区二区 | 丰满少妇在线观看资源站 | 爱爱一区 | 免费观看www视频 | 日韩欧美国产免费播放 | 韩国av电影在线观看 | 六月丁香色婷婷 | 欧美一级专区免费大片 | 国产精品久久久久免费 | 国产精品久久久久久久久久不蜜月 | 久久国产精品二国产精品中国洋人 | 国产成人av电影在线观看 | 黄色在线观看免费网站 | 夜夜爽www | 亚洲 综合 国产 精品 | 特级毛片网 | 91人人网| 中文字幕日韩精品有码视频 | 色亚洲网 | 色网站在线免费观看 | 久久色在线观看 | 在线a视频免费观看 | 国产精品入口久久 | 黄色一集片 | 国产精彩在线视频 | 一区二区三区四区五区在线视频 | 超碰在线人人艹 | 国产淫片 | 福利视频区 | 国产 一区二区三区 在线 | 69亚洲精品 | 成人a在线观看高清电影 | 久久综合欧美 | 激情视频一区 | 久久黄色网址 | 中文字幕之中文字幕 | 狠狠操电影网 | 午夜精品99久久免费 | 91精品国产91热久久久做人人 | 视频在线观看入口黄最新永久免费国产 | 国产一级免费在线 | 国内视频在线 | 热久久99这里有精品 | 在线观看免费av网 | 免费看三级网站 | 国产一区视频在线观看免费 | 亚洲三级黄 | 在线观看91久久久久久 | av在线h | 国产成人99久久亚洲综合精品 | 亚洲视频免费在线观看 | 国产一区在线播放 | 丁香六月国产 | 亚洲激情网站免费观看 | 麻豆视频免费 | 欧美日韩精 | 亚洲成av人片在线观看香蕉 | 国产不卡视频在线播放 | 国产精品99精品 | 精品欧美乱码久久久久久 | 九九在线播放 | 日韩欧美在线观看一区二区 | 欧美男同网站 | 欧美激情视频一区 | 国产 av 日韩| 最近中文字幕免费视频 | 天天操福利视频 | 四虎影视精品永久在线观看 | 午夜久久久精品 | 中文字幕亚洲字幕 | 欧美一级大片在线观看 | 国产精品乱码久久久 | 亚洲欧美日韩国产精品一区午夜 | 视频二区在线 | 91亚洲精品在线观看 | 国产成人精品综合久久久久99 | 中文字幕一区二区三区四区 | 日本中文字幕视频 | 久久99国产精品久久99 | 国产午夜av | 激情视频免费在线 | 国产精品久久久久久久免费观看 | 水蜜桃亚洲一二三四在线 | 免费看的黄色 | 麻豆 91 在线 | 久久ww | 国产色视频网站 | 国产精品久久久久久吹潮天美传媒 | 久久婷婷久久 | 97碰碰视频 | 欧美视屏一区二区 | 国产一区二区在线精品 | 日韩免费精品 | 99色99| 久久视频一区二区 | 91精品啪| 日韩xxx视频 | 国产在线观看中文字幕 | 亚洲另类久久 | 亚洲免费永久精品国产 | www.色的| 激情综合一区 | 欧美a在线看 | 黄色电影在线免费观看 | 国产午夜在线观看 | 天天做日日做天天爽视频免费 | 日韩精品无| 国产精品黄色影片导航在线观看 | 国产亚洲综合精品 | 国产成人一区二区三区电影 | 亚洲精品成人av在线 | 日韩高清免费在线 | 精品1区2区 | 欧美日韩不卡一区二区 | 日韩精品一区二区三区中文字幕 | 色综合www | 欧美99热 | 亚洲影视资源 | 欧美巨乳网 | 国产小视频免费在线观看 | 国产又粗又猛又黄视频 | 婷婷香蕉 | 久久精品精品电影网 | 色片网站在线观看 | 99久国产| 99精品视频中文字幕 | 99免费在线视频观看 | 成人一区二区三区中文字幕 | 欧美精品少妇xxxxx喷水 | 一区二区三区在线观看 | 91精品国产乱码久久桃 | 亚洲另类xxxx | 日操干| 久艹在线播放 | 99久久精品免费看 | 2021国产视频 | 日韩毛片在线免费观看 | 韩日精品在线 | 97超碰香蕉 | 97超碰免费 | 911精品视频 | 五月综合色 | 日韩午夜小视频 | 久久99久久99精品免观看粉嫩 | 五月婷丁香 | 国产粉嫩在线 | 天天操天天操天天操天天操天天操 | 视频一区在线播放 | 激情视频免费观看 | 免费在线观看成人 | av最新资源 | 欧美日韩午夜爽爽 | 国产剧情av在线播放 | 久久福利精品 | 啪啪免费观看网站 | 免费观看国产精品视频 | 一区二区三区在线电影 | 国产69久久久| 国产小视频在线免费观看 | 一区二区三区 亚洲 | 美女视频免费一区二区 | 天天人人 | 91看片在线 | 日本中文字幕一二区观 | 色综合天天综合网国产成人网 | 国产一区二区在线播放 | 久草在线久 | 99视频网址| 亚洲va天堂va欧美ⅴa在线 | 中文字幕亚洲精品日韩 | 精品视频在线视频 | 黄色aaa级片 | 免费av观看网站 | 波多野结衣视频在线 | 337p西西人体大胆瓣开下部 | 中文字幕一区二区三区精华液 | 91欧美精品 | 国产 日韩 在线 亚洲 字幕 中文 | 97精品国自产拍在线观看 | 九九精品视频在线看 | 亚洲国产中文字幕 | 午夜三级福利 | 毛片3| 7777精品伊人久久久大香线蕉 | 欧美性直播| 97国产精品久久 | 一区二区三区四区久久 | bbw av| 91在线观看黄| 视频在线观看日韩 | 天天干天天干天天色 | 国产成人在线免费观看 | 人人爽人人插 | 91免费版在线观看 | 亚洲欧美日本一区二区三区 | 成人在线播放免费观看 | 日韩欧美一区二区三区视频 | 精品国产精品久久 | 日韩电影中文 | www.久久爱.cn | 黄色精品网站 | 中文亚洲欧美日韩 | 国产做a爱一级久久 | 中文字幕国产精品 | 久久蜜臀一区二区三区av | 黄在线 | 国产一区视频导航 | 嫩小bbbb摸bbb摸bbb | 成人四虎影院 | 亚洲成av| 国产一级h | 91观看视频| 国产视频在线观看免费 | 免费在线观看国产黄 | 久久国产精品99国产精 | 黄色一级大片免费看 | 久草在线最新免费 | av免费试看 | 亚洲日本精品视频 | 欧美日韩视频 | 色资源二区在线视频 | 国产日韩精品欧美 | 超碰在线成人 | 国产视频一区二区在线 | 欧美激情第八页 | 国产高清免费av | 久久免费看 | 欧美精品久久久久久久 | 国产精品九九九 | 国产午夜不卡 | 免费看黄色毛片 | 亚洲国产高清在线观看视频 | 麻豆免费在线播放 | 色视频一区| 99爱在线观看| 超碰日韩在线 | 午夜精品一区二区三区视频免费看 | 福利视频导航网址 | 国产资源在线免费观看 | 欧美有色| 免费看特级毛片 | 中文乱码视频在线观看 | 亚洲国产激情 | 中文字幕在线观看你懂的 | 日韩在线视频二区 | 9999在线观看 | 国产区免费| 欧美日韩一区二区三区免费视频 | 日韩国产在线观看 | 国内精品免费 | 亚洲成人精品影院 | 一本一道波多野毛片中文在线 | 久久99国产精品久久99 | 久草久视频 | 91精品视频播放 | 国产69久久久 | 激情综合六月 | 色播五月激情综合网 | 999电影免费在线观看2020 | 操处女逼 | 国产免费黄视频在线观看 | 亚洲成人av在线 | 六月激情婷婷 | 91免费的视频在线播放 | 91福利在线观看 | 久草青青在线观看 | 激情丁香综合五月 | 久久影院午夜论 | 亚洲国内精品 | 狠狠色丁香久久婷婷综 | 欧美色图亚洲图片 | 国产探花在线看 | 亚洲精品视频在线观看免费 | 在线精品播放 | 欧美一级电影在线观看 | 国产精久久久久久妇女av | 国产精品18videosex性欧美 | 天天做夜夜做 | 91在线中字 | 亚洲精品网址在线观看 | 欧美欧美 | 日日夜夜免费精品视频 | 狠狠色丁香婷婷综合久小说久 | 国产日韩欧美在线观看视频 | 国产精品大片免费观看 | 最新91在线视频 | 99视频这里只有 | 成人亚洲欧美 | 制服丝袜在线 | 手机av在线网站 | 91入口在线观看 | 免费在线观看国产精品 | 欧美a视频在线观看 | 黄色电影在线免费观看 | 人人射人人插 | 国产一区二区三区高清播放 | 亚洲精品一区二区在线观看 | av黄色国产 | 久久五月婷婷丁香 | 欧美成天堂网地址 | 69久久夜色精品国产69 | 亚洲天堂网在线观看视频 | 日日摸日日 | 在线看日韩av | 正在播放国产一区二区 | 激情视频91| 免费精品在线 | 欧美91视频 | 国产黄色片在线免费观看 | 婷婷久久亚洲 | av色综合网 | 成人资源在线观看 | 国产小视频在线免费观看 | 国产伦精品一区二区三区在线 | 免费高清在线视频一区· | 日本三级国产 | 免费看网站在线 | 久久,天天综合 | 四虎影视成人永久免费观看亚洲欧美 | 日本女人的性生活视频 | 91久久精品一区二区三区 | 精品高清视频 | 三上悠亚一区二区在线观看 | 色综合久久久久久久久五月 | 日韩欧美大片免费观看 | 国产美女免费看 | 国产亚洲在线观看 | 国产一级黄 | 日韩两性视频 | 在线观看免费91 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 国产小视频网站 | 亚洲91网站 | 激情五月在线 | 欧美一区二区在线 | 91中文在线视频 | 久久综合欧美精品亚洲一区 | 国产欧美精品xxxx另类 | 中文在线免费观看 | 日韩美视频| 国产香蕉97碰碰碰视频在线观看 | 不卡的av在线 | 成人综合日日夜夜 | 一区二区三区国产精品 | 91在线入口 | 视频在线91 | 国产视频综合在线 | 国产99久久久欧美黑人 | 日韩黄色在线电影 | 成人免费视频在线观看 | 日韩大片在线播放 | 日日夜夜干 | 亚洲情感电影大片 | 99久久影视| 亚洲片在线观看 | 久久国产a | 亚洲男女精品 | 国产精品毛片一区二区三区 | 天天曰视频 | 日韩黄色免费电影 | 亚州激情视频 | 国产精品第三页 | 四虎www. | 国产在线观看 | 中文字幕传媒 | 久久精精品视频 | 97热在线观看 | 亚州精品天堂中文字幕 | 日韩理论电影在线观看 | 免费看一级一片 | 激情五月婷婷综合网 | 国产xxxx| 天天伊人狠狠 | 欧美地下肉体性派对 | 国产精品精品久久久久久 | 999亚洲国产996395 | 中文在线亚洲 | 国产精品门事件 | 国产一区免费在线观看 | 日韩.com| 国产成人精品一区二区三区在线观看 | 久久久香蕉视频 | 女人高潮一级片 | 亚洲91精品在线观看 | 丁香六月婷婷开心婷婷网 | 91亚洲精品在线 | 日日夜夜国产 | 特级毛片在线免费观看 | 中文字幕在线观看免费高清电影 | 久久中国精品 | 免费看成人av | 日韩欧美网址 | 欧美午夜性 | 国内精品久久久久久久久久清纯 | 久久综合成人网 | 亚洲精品一区二区在线观看 | av在线之家电影网站 | 99精品免费在线观看 | 欧美日韩不卡在线 | 人人超在线公开视频 | 亚洲色图 校园春色 | 免费看的黄网站 | av黄在线播放 | 日日弄天天弄美女bbbb | 摸阴视频| 在线看中文字幕 | 久草精品在线播放 | 国产五月色婷婷六月丁香视频 | 久久涩涩网站 | 在线 影视 一区 | 精品国产亚洲一区二区麻豆 | 韩国视频一区二区三区 | 久久综合色婷婷 | 黄色大片中国 | 中文字幕在线国产精品 | 成人国产精品免费观看 | 国产精品女教师 | 午夜av一区二区三区 | 欧美日韩调教 | 午夜精品一区二区三区可下载 | 国产福利91精品张津瑜 | 久久无码av一区二区三区电影网 | 国产一级做a爱片久久毛片a | 欧美亚洲国产一卡 | 欧美在线观看视频一区二区 | 精品主播网红福利资源观看 | 激情视频网页 | 久久超级碰 | 日日干夜夜干 | 亚洲干视频在线观看 | 伊人天天狠天天添日日拍 | 免费一级特黄毛大片 | 日韩美女高潮 | 日韩一区二区三区高清在线观看 | 欧美a免费 | 色噜噜在线观看 | 国产无吗一区二区三区在线欢 | 一区二区视 | 午夜色大片在线观看 | 亚洲三级国产 | 天天射天天干天天插 | 精品视频在线视频 | 成人性生交大片免费看中文网站 | 亚洲免费精品一区二区 | 国产亚洲久一区二区 | 人人插人人插 | 九九热.com| 色噜噜日韩精品一区二区三区视频 | 亚洲欧美日韩精品久久奇米一区 | 日韩电影在线观看一区二区三区 | 免费瑟瑟网站 | 日日干日日色 | 国产96在线观看 | 久草在线 | 免费久久精品视频 | 成年人在线看片 | 欧美经典久久 | 九色91av | 欧美a免费 | 超碰资源在线 | 日韩伦理片一区二区三区 | 国产黄色大片 | 国产麻豆剧果冻传媒视频播放量 | 亚洲波多野结衣 | 久久久久久久影视 | 一本色道久久精品 | 中文字幕在线日亚洲9 | 97超碰色 | 久久久视频在线 | 国产视频欧美视频 | 二区视频在线观看 | 成人欧美一区二区三区在线观看 | 久久成电影 | 精品国产一区二区三区四区在线观看 | av网站有哪些 | 欧美精品国产综合久久 | 中中文字幕av在线 | 深爱婷婷 | 国产成人精品一区二区三区福利 | 三级黄免费看 | 久久免费影院 | 97国产在线 | av电影一区二区三区 | 亚洲美女视频在线 | 亚洲视频 视频在线 | 亚洲成人资源在线观看 | 伊人五月天综合 | 日韩电影中文字幕在线观看 | 国产精品久久久网站 | 天天干天天草 | 亚洲国产中文字幕在线观看 | 三级黄色理论片 | 久久久久久久亚洲精品 | 国产美女免费观看 | 欧美性生活免费 | 狠狠的日 | 国产成人在线网站 | 叶爱av在线 | 久久综合九色欧美综合狠狠 | 一本一道波多野毛片中文在线 | 亚洲国产精品va在线看黑人动漫 | 亚洲欧美国产精品久久久久 | 久久夜靖品| 中文字幕一区二区三区乱码在线 | 亚洲欧美日韩国产精品一区午夜 | 亚洲日韩中文字幕 | 久久精品在线免费观看 | 精品国偷自产国产一区 | 日日添夜夜添 | 久爱精品在线 | av国产在线观看 | 国产精品一级在线 | 久久中文字幕导航 | 久久免费视频播放 | 高清av免费一区中文字幕 | 四月婷婷在线观看 | 国产一区在线观看免费 | 色网站黄 | 五月天伊人网 | 一区二区三区免费在线 | 久久久亚洲麻豆日韩精品一区三区 | 免费看毛片网站 | 国产精品白虎 | 欧美黑吊大战白妞欧美 | 九九视频在线观看视频6 | 美女网站黄免费 | 韩日av在线 | 久久精品免费 | 国产区欧美 | 美女网站视频免费黄 | 五月天免费网站 | 黄色在线观看污 | 国产精品av在线免费观看 | 九九九九九九精品任你躁 | 成人av中文字幕 | 黄色a视频免费 | 成人在线免费视频 | 婷婷亚洲最大 | 91精品久久久久久久91蜜桃 | 最近最新mv字幕免费观看 | 少妇做爰k8经典 | 国产免费又粗又猛又爽 | 最新中文字幕视频 | 人人爽人人香蕉 | www婷婷 | 亚洲精品乱码久久久久久按摩 | 精品在线观看一区二区三区 | 91看片在线免费观看 | 黄色免费网站 | 波多野结衣一区二区 | 日韩经典一区二区三区 | 日韩美一区二区三区 | 国产色妞影院wwwxxx | 又湿又紧又大又爽a视频国产 | 香蕉视频导航 | 国产精品久久久久久久久久ktv | 久久免费精品国产 | 91福利视频久久久久 | 99久久久国产精品免费99 | 久久视频免费看 | 日韩亚洲国产中文字幕 | 在线观看中文字幕第一页 | 午夜精品在线看 | www日韩精品 | www.日日操.com| 99精品久久久 | 日本特黄特色aaa大片免费 | 又黄又刺激的视频 | 操高跟美女 | 免费在线播放 | 丁香婷婷基地 | 国产一区二区在线免费播放 | 福利视频在线看 | 久草网站| 亚洲在线视频播放 | 国产美女网站在线观看 | 国产精彩在线视频 | 国外调教视频网站 | 国产免费久久av | 国产精品一区久久久久 | 麻豆精品传媒视频 | 毛片网免费 | 国产老太婆免费交性大片 | 日韩中文字幕在线 | 久久精品视频免费播放 | 天天色综合久久 | 狠狠操.com| 亚洲欧美国内爽妇网 | 韩国三级在线一区 | 中文字幕乱视频 | 成 人 黄 色 视频播放1 | 久草五月 | 国产视频在线播放 | 亚洲免费在线观看视频 | 亚洲高清精品在线 | 久热色超碰 | 69精品在线观看 | 免费一级毛毛片 | 亚洲激情综合 | 天天爽夜夜爽精品视频婷婷 | 日韩二区三区在线 | 亚洲无在线 | 天天操天天摸天天干 | 免费看三级 | 免费不卡中文字幕视频 | 国产一级不卡视频 | 亚洲精品在线观看网站 | 99热九九这里只有精品10 | 日韩网站中文字幕 | 亚洲经典视频在线观看 | 国产精国产精品 | 精品亚洲男同gayvideo网站 | 国产麻豆视频网站 | 成人在线黄色电影 | 在线日韩| 欧美激情视频一二三区 | 国产在线中文 | 国内视频在线观看 | 在线观看免费 | 视频在线精品 | 免费精品视频在线观看 | 天天爱天天操天天爽 | 精品亚洲欧美一区 | 欧美 激情在线 | 国内亚洲精品 | 亚洲一区视频在线播放 | 精品日韩视频 | 欧美另类视频 | 超碰.com| 成人少妇影院yyyy | 精品国产一区二区久久 | 伊人久久精品久久亚洲一区 | 在线观看视频在线观看 | 又黄又爽免费视频 | 久久久久区| 超碰人人乐 | 中文字幕网址 | 操操操com | 久久精品欧美 | 日韩成人邪恶影片 | 国产精品电影一区二区 | 欧美国产一区二区 | 国产精品久久久久久久久久免费看 | 69国产精品视频免费观看 | 欧美极品少妇xbxb性爽爽视频 | 91桃色在线观看视频 | 免费福利片2019潦草影视午夜 | 激情欧美日韩一区二区 | 亚洲午夜久久久久久久久电影网 | 亚洲成av| 亚洲首页 | 国内精品免费久久影院 | 在线精品观看国产 | 激情综合五月天 | 国产精品a成v人在线播放 | 免费观看一区 | 五月天六月婷 | 国产字幕在线播放 | 毛片视频电影 | 麻豆视频免费观看 | 久久久久久久久久网站 | 色橹橹欧美在线观看视频高清 | 一区久久久 | 99国产在线观看 | 久久精品5 | www.色午夜| 九色91av| 91在线播放综合 | 美女av免费看 | 国产精品综合久久久 | 免费特级黄色片 | 日韩精品一区二区三区在线视频 | 中文字幕日本在线 | 黄色小视频在线观看免费 | 中文字幕 在线看 | 四虎永久视频 | 在线天堂日本 | 国产伦理精品一区二区 | 国产在线精品国自产拍影院 | 日日操夜| 91最新在线| 91禁在线看 | 99r在线精品 | 少妇bbw撒尿| 在线香蕉视频 | 久色小说 | 亚洲成人频道 | 俺要去色综合狠狠 |