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

臟讀、幻讀,要想搞懂不容易!

數據庫 MySQL
臟讀、幻讀、不可重復讀、當前讀、快照讀,這些名詞經常搞的讓人頭暈。因為一般人大腦的主線就是單線程的,并不能一次性處理多個事務。

[[394503]]

本文轉載自微信公眾號「小姐姐味道」,作者小姐姐養的狗02號。轉載本文請聯系小姐姐味道公眾號。   

臟讀、幻讀、不可重復讀、當前讀、快照讀,這些名詞經常搞的讓人頭暈。因為一般人大腦的主線就是單線程的,并不能一次性處理多個事務。

要想記憶深刻,我們得借助幾個實例。讀完本文,你一定會豁然開朗,忍不住三連走起。

但在這之前,我們需要看一下當前的數據庫隔離級別,到底是什么。比如MySQL。

  1. select @@tx_isolation; 

MySQL就包含4種隔離級別,隔離的當然是數據。要修改隔離級別的話,可以使用下面的SQL語句。

  1. set session transaction isolation level read uncommitted
  2. set session transaction isolation level read committed
  3. set session transaction isolation level repeatable read
  4. set session transaction isolation level serializable

ok,我們創建一張小小的測試表,來看一下并發環境下的魔幻效果。

  1. CREATE TABLE `xjjdog_tx` ( 
  2.  `id` INT(11) NOT NULL
  3.  `nameVARCHAR(50) NOT NULL COLLATE 'utf8_general_ci'
  4.  `money` BIGINT(20) NOT NULL DEFAULT '0'
  5.  PRIMARY KEY (`id`) USING BTREE 
  6. COLLATE='utf8_general_ci' 
  7. ENGINE=InnoDB 
  8. INSERT INTO `xjjdog_tx` (`id`, `name`, `money`) VALUES (2, 'xjjdog1', 100); 
  9. INSERT INTO `xjjdog_tx` (`id`, `name`, `money`) VALUES (1, 'xjjdog0', 100); 

1. 臟讀

臟讀,意思就是讀出了臟數據。啥叫臟數據?就是另外一個事務還沒有提交的數據。在read uncommitted隔離級別下,就會出現臟讀。比如下面這個時序

  1. 事務 A:set session transaction isolation level read uncommitted
  2. 事務 B:set session transaction isolation level read uncommitted
  3. 事務 A:START TRANSACTION ; 
  4. 事務 B:START TRANSACTION ; 
  5. 事務 A:UPDATE xjjdog_tx SET money=money+100 WHERE NAME='xjjdog0'
  6. 事務 B:UPDATE xjjdog_tx SET money=money+100 WHERE NAME='xjjdog0'
  7. 事務 A:ROLLBACK ; 
  8. 事務 B:COMMIT ; 
  9. 事務 B:SELECT * FROM xjjdog_tx ; 

在這個場景下,money的原始值為100,分別在兩個session中進行了加100的操作,然后回滾了其中的一個session事務。結果,經過查詢,發現money的值保持100不變。也就是其中一次加100的操作被覆蓋掉了。

所以臟讀發生有幾個條件。

  • 高并發場景,在一個事務A開始之后還沒結束之前,有另外一個事務參與了事務A所涉及的數據行讀寫
  • 事務隔離級別處于最低的讀未提交
  • 在你使用到這些數據之后,事務A回滾,造成你之前拿到的數據已經不再存在

解決方式,只需要設置成隔離級別比read uncommitted高即可。

2. 不可重復讀

把隔離級別設置成read committed即可避免臟讀,這其實非常好理解。臟讀產生的根本原因就是在事務的執行期間有別的操作亂入,這個隔離級別要求事務A提交之后,修改后的值,才能被事務B讀到,所以臟讀是不可能會發生的,從根本上杜絕了。

但read commited會發生不可重復讀的情況。

顧名思義,就是在一個事務周期內,對于一個值的讀取,產生了兩個結果。

不可重復讀,證明了世界并不是總圍繞著你轉的。在你的事務執行期間,會有無數的其他事務執行,如果你的事務持續時間超過了這些事務,那么你就可能讀到兩個或者更多的值。

讓我來給你講一個故事。

從前,有一顆桃樹,長了12棵桃子。有一只猴子,叫做xjjdog,它想吃上面的桃子,但桃子還不熟。

第二天去看的時候,它發現桃子少了一個,變成了11個,經過仔細打聽,原來是被猴子A搶先吃掉一個。

第二天去看的時候,桃子又少了一個,變成了10個,原來是被饞嘴的猴子B吃掉一個。

如此這般,桃子一天天少了下去,只剩下最后的2個了,但桃子還是沒熟。

再不摘桃子就沒了,xjjdog摘下了最后的2個桃子,正打算大快朵頤,結果跳出一只猴子X,說我盯著這些桃子已經1年了...

在這故事中,猴子A、B的事務持續周期是1天;xjjdog的事務持續周期是直到桃子成熟;猴子X的持續周期更長,可能是一年。它們每天看到的桃子,并不總是12個。今天的桃子,可能被其他的猴子(事務)給吃掉了,造成了觀測的結果是不一樣的,這就是不可重復讀的概念。

有時候,即使讀到的值是一樣的,也不能證明沒問題。比如有財務挪用了2億去炒股,然后在月底把2億還了回來,雖然最終的金額都是一致的,但由于你的對賬周期長,就發現不了這種差異。

如何解決不可重復讀呢?先要看一下不可重復讀是不是問題。

有的系統,要求的就是這樣的邏輯,每次在事務中讀取到不一樣的值,它是可以忍受的。但如果你想要在桃子成熟之前,桃子的數量都在你的掌控之中,那不可重復讀就是一種問題。

一種非常好的方式,就是xjjdog一直站在桃樹地下。當有別的猴子想要摘桃,就把它趕走。這種方式可行,但在數據庫中非常低效,這是serializable級別的做法。

MySQL有一個默認的事務隔離級別,叫做repeatable read,使用了MVCC的方式(innodb),要更輕量級一些。

3. 可重復讀

這就是MVCC(Multi-Version Concurrency Control)的功勞了,它有三個特點。

每行數據都存在一個版本,每次數據更新時都更新該版本

修改時,拷貝一份,當前版本隨意修改,事務之間無干擾

保存時比較版本號,如果成功commit覆蓋原記錄,失敗則rollback

MVCC在InnoDB中的實現主要是為了提高數據庫并發性能,用更好的方式去處理讀-寫沖突,做到即使有讀寫沖突時,也能做到不加鎖,非阻塞并發讀。它的實現關鍵也有三項技術:

  1. 3個隱式字段:DB_TRX_ID,最近修改它的事務ID;DB_ROLL_PTR,回滾指針,指向上一個版本;DB_ROW_ID,隱藏主鍵
  2. undo日志:的對同一記錄的修改,會生成針對此記錄的版本變更鏈表
  3. read view:快照讀操作的時候,產生的讀視圖。除了使用上面的額外信息,它也會維護一個活躍的事務ID集合

一切的關鍵,就在于快照這兩個字上面。

比如事務A對某個記錄進行了快照讀,那么在快照讀的這一刻,就生成了一個Read View。在這一刻,事務B和C,還沒有commit,事務D和E,在建立ReadView那一刻之前,commit完成,那么這個Read View,就不能夠讀到B和C的修改。

但可惜的是,可重復讀,只能解決快照讀的不可重復讀,快照讀的時機,也會影響讀取的準確程度。請看下面兩種情況。

下面這種情況讀到的是500。

事務A 事務B
開啟事務 開啟事務
快照讀(無影響)查詢金額為500 快照讀查詢金額為500
更新金額為400  
提交事務  
  select 快照讀金額為500
  select lock in share mode當前讀金額為400

下面這種情況讀到的是400。

事務A 事務B
開啟事務 開啟事務
快照讀(無影響)查詢金額為500  
更新金額為400  
提交事務  
  select 快照讀金額為400
  select lock in share mode當前讀金額為400
 

(表格來自[SnailMann]的博客)。

4. 幻讀

幻讀,這個詞本身就非常的迷幻。在RU、RC、RR級別下,都會出現幻讀。

拿一個最簡單的例子來說。讓你select一條記錄是否存在然后打算進行后續插入時,如果這條記錄不存在,然后你執行了插入操作,但在實際執行插入操作的時候,結果卻報錯了,這條記錄已經存在了,這就是幻讀。

首先,確認目前時可重復讀級別。如果不是,則修改之。

  1. SELECT @@tx_isolation 
  2. set session transaction isolation level repeatable read 

讓我們來看一下這個靈異過程。

有5個步驟,我都給你標好了。下面一一介紹。

  1. 事務A使用begin開啟一個事務,然后查詢id為3的記錄,此時不存在。但由于快照讀開啟了一個針對于id為3的記錄的read view,所以在這個事務自始至終都不能夠讀到為3的記錄。很好,這就是我們不可重復讀所需要的
  2. 接下來,事務B插入了一條id為3的記錄,并提交成功
  3. 事務A此時也想插入這條記錄,于是執行了相同的插入操作,結果數據庫報錯,顯示這條記錄已經存在
  4. 事務A此時一臉懵逼,想看一下這條記錄到底是啥,但當它再次執行select語句的時候,卻查不到這條記錄
  5. 但在其他事務中,是可以看到這條記錄的,因為它已經正確提交

這就是幻讀。

5. 如何解決幻讀

幻讀有錯么?多數情況下沒錯,就是報錯怪異了些。要防止幻讀,需要開啟FOR UPDATE這樣高強度的鎖定,實際情況是非常少用。

為什么上面的操作,insert能報錯,但select卻無法查到數據呢?這就不得不提一下數據庫讀的兩種模式:

快照讀:普通的select操作,是從read view中讀取數據,讀取的可能是歷史數據

當前讀:insert、update、delete、select..for update這種操作,讀取的總是當前的最新數據

對于當前讀,你讀取的行,以及行的間隙都會被加鎖,直到事務提交時才會釋放,其他的事務無法進行修改,所以也不會出現不可重復讀、幻讀的情形。所以insert能夠發現沖突,而普通select卻不可以。要想解決幻讀,就需要加X鎖。在上面這種情況,就可以在事務A中執行:

  1. SELECT * FROM xjjdog_tx WHERE id=3 FOR UPDATE 

當這么做的時候,即使id為3的記錄不存在,它也會創建鎖(在背后可能根據記錄的存在與否加行X鎖或者next-key lock間隙x鎖)。

6. 總結

下面簡單總結一下。

臟讀,就是一個事務讀取到另一個事務還沒有提交的記錄。當其他事務發生回滾的時候,就會出現問題。

不可重復讀,意思是在同一個事務里,讀多次可能會獲得不一致的結果。這是因為在事務執行期間,有別的事務修改了這些記錄。

MySQL默認是可重復讀,但會發生幻讀的情況?;米x是由于快照讀和當前讀的差別產生的。

要想解決幻讀,就需要加鎖(X鎖,Gap鎖等),比如for update,全部改成當前讀直到事務結束,自然沒有問題。

所謂的最高級別serializable,不過是全部搞成了當前讀而已,在高并發的環境下效率,可想而知。所以幾乎沒有用的。

作者簡介:小姐姐味道 (xjjdog),一個不允許程序員走彎路的公眾號。聚焦基礎架構和Linux。十年架構,日百億流量,與你探討高并發世界,給你不一樣的味道。我的個人微信xjjdog0,歡迎添加好友,進一步交流。

 

責任編輯:武曉燕 來源: 小姐姐味道
相關推薦

2022-01-03 07:18:05

臟讀幻讀 MySQL

2024-04-19 08:18:47

MySQLSQL隔離

2019-03-21 09:06:00

數據庫復讀幻讀

2022-04-27 07:32:02

臟讀幻讀不可重復讀

2024-04-24 08:26:35

事務數據InnoDB

2020-06-09 08:19:25

微服務網站架構

2012-06-13 14:58:09

BYOD移動辦公

2023-08-09 17:22:30

MVCCMySQL數據

2023-11-01 14:13:00

MySQL事務隔離級別

2020-06-18 10:52:17

運維架構技術

2017-04-27 13:30:14

AndroidWebView移動應用

2018-01-24 07:28:20

2013-09-22 09:16:25

碼農程序員黑客

2009-02-12 17:25:21

Windows7試用下載

2009-09-04 08:19:24

Windows 7優缺點

2025-02-26 10:40:44

數據庫并發幻讀

2023-08-31 22:17:15

JavaMySQLB+樹

2011-12-16 14:52:55

移動互聯聯想

2022-06-30 08:00:00

MySQL關系數據庫開發

2024-09-02 00:00:00

MySQL幻讀數據
點贊
收藏

51CTO技術棧公眾號

在线看免费毛片| 国产精品亚洲不卡a| 黄大色黄女片18免费| 国产精品99| 亚洲精品五月天| 国产精品制服诱惑| 日本中文字幕在线| 四虎8848精品成人免费网站| 欧美sm极限捆绑bd| 国产福利影院在线观看| 成人在线免费看片| 97久久超碰国产精品电影| 国产精品第3页| 欧美精品一级片| 国产日产精品一区二区三区四区的观看方式 | 国产91麻豆视频| 免费视频一区| 美女福利视频一区| 成年人免费观看视频网站| 国产精品亚洲欧美一级在线 | 亚洲国产一二三精品无码 | 国精品产品一区| 天天亚洲美女在线视频| 亚洲欧美在线网| 蜜桃91麻豆精品一二三区| 视频一区视频二区在线观看| 精品少妇一区二区30p| 九色porny自拍视频| 亚洲超碰在线观看| 欧美日韩精品一二三区| 精品国产免费av| 中文字幕伦理免费在线视频| 国产精品美女久久久久久久久久久 | 日韩av在线天堂网| 成人高清在线观看视频| 欧美成人精品三级网站| 亚洲成人自拍网| 国产又大又长又粗又黄| 国产h在线观看| www.欧美.com| 岛国一区二区三区高清视频| 一级α片免费看刺激高潮视频| 妖精视频成人观看www| 欧美床上激情在线观看| 久久av红桃一区二区禁漫| 精品freesex老太交| 亚洲激情视频在线| aaa黄色大片| 国产在线一区不卡| 欧美美女网站色| 性欧美videossex精品| 三上悠亚一区二区| 一本久久a久久免费精品不卡| 国产精品久久中文字幕| 波多野结依一区| 一区二区三区波多野结衣在线观看 | 中文字幕成人在线视频| 在线一区视频观看| 一本色道亚洲精品aⅴ| 北条麻妃69av| 水蜜桃在线视频| 一本色道久久加勒比精品 | 蜜臀av一区二区在线免费观看 | 国产精品美女在线播放| 国产在线观看av| 亚洲免费观看高清完整版在线观看 | 欧美高清一级大片| 黄色一级视频免费观看| 韩国久久久久| 午夜精品一区二区三区在线 | 午夜天堂精品久久久久| 久久99精品视频一区97| 久久精品视频日本| 亚洲黄色av| 亚州欧美日韩中文视频| 丁香六月婷婷综合| 日韩高清一级片| 国产三级精品网站| 精品久久久中文字幕人妻| 国产传媒一区在线| 久久精品ww人人做人人爽| 深夜福利视频一区| 中文字幕精品三区| 99热都是精品| 国产三级伦理在线| 欧美性猛交xxxx乱大交极品| 黄色三级视频片| 91精品国产自产观看在线| 欧美一区二区三区播放老司机| 无码人妻久久一区二区三区蜜桃 | 欧美影视一区二区| 999在线视频| 亚洲美女一区二区三区| 精品久久久久久久久久中文字幕| 中文av在线全新| 欧美日韩色一区| 久久久男人的天堂| 精品久久成人| 欧美日韩爱爱视频| 无码人妻精品一区二区三区蜜桃91 | 中文乱码免费一区二区| 日本香蕉视频在线观看| 日韩三区在线| 日韩美女视频在线| av在线网站观看| 国产精品99久久| 性亚洲最疯狂xxxx高清| 一本色道久久综合亚洲| 99视频精品全部免费在线| 亚洲电影免费| 精精国产xxxx视频在线播放| 欧美人狂配大交3d怪物一区| 国产伦精品一区二区三区精品| 精品久久久亚洲| 欧美黑人巨大xxx极品| 中文在线字幕av| 成人av在线一区二区三区| 亚洲五月六月| 超碰一区二区| 欧美大片拔萝卜| 精品一区二区6| 亚洲一区国产一区| 5g影院天天爽成人免费下载| 成人精品一区二区三区免费 | 成人在线视频一区二区| 亚洲精品成人三区| 日本不卡1234视频| 精品久久久久av影院| 国产精品18在线| 久久精品导航| 国内精品久久国产| 亚洲性图自拍| 欧美日韩国产天堂| 中文字幕免费视频| 国产精品日韩久久久| αv一区二区三区| www国产在线观看 | 亚洲 欧美 另类人妖| 综合综合综合综合综合网| 欧美激情aaaa| 精品国产伦一区二区三| 国产精品不卡视频| 孩娇小videos精品| 日韩激情图片| 国产精品视频yy9099| 加勒比一区二区三区在线| 亚洲r级在线视频| 黄色国产在线视频| 亚洲高清二区| 国产一区免费在线| 欧美人动性xxxxz0oz| 日韩美女主播在线视频一区二区三区 | 成人爽a毛片免费啪啪红桃视频| 日韩有码视频在线| 国产精品久久久国产盗摄| 日韩一区在线播放| 日本一二三区在线| 欧美99久久| 国产99在线播放| 白浆在线视频| 亚洲精品网址在线观看| 亚洲图片在线视频| 中文av一区特黄| 五月激情五月婷婷| 久久久久久久久久久久久久| 91牛牛免费视频| 色女人在线视频| 欧美成人a视频| 国产精品一区二区6| 91麻豆精东视频| 欧洲熟妇精品视频| 91日韩在线| 91嫩草在线| 电影在线观看一区| 亚洲日韩中文字幕在线播放| 亚洲精品毛片一区二区三区| 国产精品三级av在线播放| 国产女同无遮挡互慰高潮91| 综合激情婷婷| 精品日韩美女| 少妇精品视频一区二区免费看| 视频在线观看一区二区| av男人天堂网| 香蕉成人啪国产精品视频综合网| 日本黄色网址大全| 九色|91porny| 无码专区aaaaaa免费视频| 久久99精品久久久久久园产越南| 国产区精品视频| brazzers在线观看| 国产一区二区三区在线观看视频| 91福利免费视频| 午夜伊人狠狠久久| 东方伊人免费在线观看| 国产福利精品导航| 成人免费xxxxx在线视频| 亚洲成人精品| 欧美日韩精品一区| 久久精品免视看国产成人| 91av在线看| 毛片在线不卡| 亚洲精品乱码久久久久久金桔影视| 亚洲av无码乱码国产精品fc2| 伊人开心综合网| 一级片手机在线观看| 国产精品小仙女| 青青在线免费观看视频| 亚洲国产精品一区| 亚洲国产欧美一区二区三区不卡| 999久久精品| 国产精品入口夜色视频大尺度| 超碰97免费在线| 色诱女教师一区二区三区| 天天干天天干天天干| 欧美精品123区| 怡红院av久久久久久久| 亚洲高清不卡在线观看| 国产亚洲精品久久久久久豆腐| 2020国产精品自拍| 中文字幕1区2区| 精品综合久久久久久8888| 日本精品免费在线观看| 激情国产一区| 成年在线观看视频| 国产精品久久久久久久久久10秀| 日本一区二区久久精品| 久久365资源| 亚洲va电影大全| 国产精品黄色片| 国产精品草莓在线免费观看| 黄色软件视频在线观看| 欧美高清视频免费观看| 成人a在线视频免费观看| 在线国产精品播放| 成人在线播放视频| 亚洲色图欧美制服丝袜另类第一页| 韩国av在线免费观看| 日韩视频在线观看一区二区| 91欧美日韩麻豆精品| 欧美在线色视频| 91青青草视频| 在线看国产一区二区| 成人毛片在线播放| 欧美性猛交xxxx免费看漫画| 日本少妇性生活| 亚洲国产精品一区二区久久| 青青草手机在线视频| 亚洲日本va午夜在线影院| 97在线观看视频免费| 1区2区3区国产精品| 欧美福利在线视频| 国产精品久久久久久久久免费樱桃| japanese中文字幕| 久久精品欧美日韩精品| 日本少妇高潮喷水xxxxxxx| 久久婷婷国产综合精品青草| 一本加勒比北条麻妃| 久久久久国产精品麻豆ai换脸 | 国产欧美日韩精品一区| 嘿嘿视频在线观看| 国产精品对白交换视频| 天天看天天摸天天操| 亚洲狼人国产精品| 亚洲激情视频一区| 日韩欧美在线视频日韩欧美在线视频| 亚洲GV成人无码久久精品| 在线精品视频免费观看| 夜夜狠狠擅视频| 欧美一级在线免费| 色香蕉在线视频| 一级做a爰片久久毛片美女图片| av网站无病毒在线| 草民午夜欧美限制a级福利片| 日韩在线观看www| 欧美成在线视频| 丝袜老师在线| 国产美女精品视频免费观看| 国产一区二区三区国产精品| 国产精品午夜av在线| 欧美日韩播放| 日本丰满少妇黄大片在线观看| 黄色av成人| 日韩中文字幕免费在线| 国产一区二区久久| 亚洲成人av免费在线观看| 国产欧美一区二区精品婷婷| 欧美特级一级片| 日韩欧美精品免费在线| 一级黄色片网站| 亚洲第一网站免费视频| 番号集在线观看| 欧美日韩xxx| 三级成人在线| 91久久偷偷做嫩草影院| 国产成人短视频在线观看| 日韩精品一区二区三区电影| 男女精品视频| 亚洲欧美一区二区三区不卡| 久久亚洲私人国产精品va媚药| 黄色录像二级片| 欧美视频在线免费| 国产精品一区二区三区在线免费观看| 日韩精品久久久久久久玫瑰园| 免费黄网在线观看| 欧美在线免费观看| 嫩呦国产一区二区三区av| 欧美成人免费在线| 国产精品magnet| 亚洲综合日韩欧美| 99久久国产综合精品麻豆 | 亚洲第一狼人社区| 国产乱码在线观看| 亚洲黄色www| 最爽无遮挡行房视频在线| 国产高清视频一区三区| 波多野结衣欧美| 熟妇熟女乱妇乱女网站| 免费欧美日韩国产三级电影| 免费的av网站| 一区二区三区产品免费精品久久75| 做爰视频毛片视频| 日韩精品中文字幕有码专区| 牛牛在线精品视频| 成人福利视频在线观看| 国产一区二区精品久| 国产乱子伦农村叉叉叉| 成人综合婷婷国产精品久久| 亚洲 欧美 变态 另类 综合| 在线观看免费视频综合| 天堂av中文字幕| 欧美激情第1页| 国产精品亚洲欧美一级在线| 亚洲欧洲另类精品久久综合| 视频一区视频二区在线观看| 最新中文字幕视频| 欧美日韩在线另类| 色婷婷av一区二区三区之e本道| 欧美大胆在线视频| 国产日本亚洲| 91免费视频黄| 黄色日韩网站视频| 国产精品精品软件男同| 精品1区2区3区| √新版天堂资源在线资源| 国产精品com| 精品一区二区三| 青青草精品视频在线观看| 久久精品欧美一区二区三区不卡| 丁香社区五月天| 一区二区欧美久久| 日本黄色一区| 天堂精品视频| 久久99九九99精品| www.97视频| 日韩一区二区在线观看视频播放| av网站大全在线| 91国产在线播放| 亚洲视频免费| 日本黄色免费观看| 一本到三区不卡视频| porn亚洲| 成人xxxxx| 欧美日韩一区二区国产| 国产精品手机在线观看| 好吊成人免视频| 粉嫩av一区| 91九色国产社区在线观看| 欧美黄色aaaa| 成人精品在线观看视频| 在线观看三级视频欧美| 日本高清视频在线播放| 99视频免费观看| 国产欧美三级| 91成人精品一区二区| 欧美一区二区国产| 黄在线观看免费网站ktv| 日本午夜精品一区二区| 国产一区二区调教| 国产主播在线观看| 国产亚洲精品va在线观看| 9999在线精品视频| 国产精品成人久久电影| 国产清纯在线一区二区www| 一本色道久久综合亚洲| 午夜精品一区二区三区在线播放| 日韩精品导航| 岛国av免费在线| 欧美日韩免费网站| 中文字幕在线观看日本| 成人综合色站| 秋霞午夜鲁丝一区二区老狼| 一级黄色录像视频| 亚洲欧美日韩国产精品| 成人av在线播放| www黄色av| 依依成人综合视频| 国产精品一二三区视频| 国产二区不卡| 美女视频黄免费的久久| 色网站在线播放|