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

MySQL存儲過程中的錯誤處理

數據庫 MySQL
今天我們要講的是如果在存儲過程中遇到錯誤應該如何處理。因為存儲過程中是很多條 SQL 語句構成的 FUNCTION 或者 PROCEDURE,發生的錯誤通常會影響代碼的執行,因此妥善的處理錯誤是很重要的,比如繼續或者退出執行當前代碼塊,并給出一個容易理解的錯誤信息。

本文主要基于一篇 MySQL Tutorial的文章,同時補充了自己的幾個實踐。

概述

我們在執行普通的 MySQL SQL 語句的時候,都會在某些情況下遇到錯誤。比如,我們向一張表中插入一條已經存在的記錄,導致了主鍵重復,會出現如下的錯誤:

 上圖中標記為紅色的部分,就是 MySQL 返回的錯誤信息在 mysql 命令行客戶端中的提示。里面有兩個值得注意的部分:

  1. MySQL 錯誤碼:就是 ERROR 后面的 1062, MySQL 自定義的錯誤代碼,跟其他數據庫不通用。
  2. SQLSTATE 代碼:就是 錯誤碼后面的 (23000)。五位字符,從 ANSI SQL和 ODBC 來的標準化的錯誤代碼,跟錯誤碼之間并沒有一一對應的關系。

MySQL 的錯誤碼和 SQLSTATE 的具體信息可參見官方手冊:Server Error Codes and Messages

今天我們要講的是如果在存儲過程中遇到錯誤應該如何處理。因為存儲過程中是很多條 SQL 語句構成的 FUNCTION 或者PROCEDURE,發生的錯誤通常會影響代碼的執行,因此妥善的處理錯誤是很重要的,比如繼續或者退出執行當前代碼塊,并給出一個容易理解的錯誤信息。

MySQL 提供了一個簡單的手段,即定義錯誤處理器(Handler),來捕獲從通用的警告或者異常,到更具體的錯誤碼等各種錯誤條件。

聲明一個錯誤處理器

聲明一個錯誤處理器所需的 DECLARE HANDLER 語句格式如下:

  1. DECLARE action HANDLER FOR condition_value statement; 

如果一個錯誤條件的值符合 condition_value,MySQL 就會執行對應的 statement,并根據 action 指定關鍵字確定是 繼續 還是退出 當前的代碼塊(譯者注,當前代碼塊就是包含此錯誤處理器的最近的那對 BEGIN 和 END圍出來的代碼段)。

參數 action 可以取以下兩個值:

  • CONTINUE : 當前代碼段會從出錯的地方繼續執行。
  • EXIT : 當前代碼段從出錯的地方終止執行。

condition_value 指定了會激活錯誤處理器的一個特定的條件或者一類錯誤條件。其取值可以是:

  • 一個 MySQL 錯誤碼
  • 一個標準的 SQLSTATE 值。或者可以是 SQLWARNING , SQLEXCEPTION 等條件,這些分別代表一組類似的 SQLSTATE值。NOTFOUND 條件則可用于游標或者 SELECT INTO variable_list 語句,表示沒有找到匹配的數據行。
  • 一個與特定 MySQL 錯誤代碼或者 SQLSTATE 值關聯的命名條件,說白了就是個別名。

statement 則可以是個簡單的語句或者被 BEGIN 和 END 圍起來的多條語句。

MySQL 錯誤處理器示例

我們先看幾個聲明錯誤處理器的例子:

下面的處理器指出:如果發生了錯誤,就將 has_error 變量的值設為 1 并繼續執行出錯的語句所在的代碼塊。

  1. DECLARE CONTINUE HANDLER FOR SQLEXCEPTION SET has_error = 1; 

下面是另一個錯誤處理器,指出如果發生任何錯誤就回滾之前的操作,給出一條錯誤信息,并退出當前代碼塊的執行。如果你是在聲明存儲過程的 BEGIN 和 END 語句之間聲明的這個錯誤處理器,那么出錯時會立即結束整個存儲過程的執行。

  1. DECLARE EXIT HANDLER FOR SQLEXCEPTION 
  2. BEGIN 
  3. ROLLBACK
  4. SELECT 'An error has occurred, operation rollbacked and the stored procedure was terminated'
  5. END 

下面的錯誤處理器指出,如果有發生數據行不存在的錯誤,其實就是指在使用游標(Cursor)或者SELECT INTO語句的情況,就把no_row_found 變量設為1,并繼續執行。

  1. DECLARE CONTINUE HANDLER FOR NOT FOUND SET no_row_found = 1; 

譯者注:如果只是為了檢查 SELECT INTO 是否有行數據返回,MySQL 還有另外一個 FOUND_ROWS() 內置函數可以用。

下面的錯誤處理器指出,如果發生了主鍵重復的錯誤(MySQL的錯誤碼為1062),就將給出一條錯誤提示并繼續代碼塊的執行:

  1. DECLARE CONTINUE HANDLER FOR 1062 
  2. SELECT 'Error, duplicate key occurred' 

存儲過程中出錯處理的示例

首先為了演示我們創建一張新表,表名是 article_tags:

  1. CREATE TABLE article_tags( 
  2.     article_id INT
  3.     tag_id     INT
  4.     PRIMARY KEY(article_id,tag_id) 
  5. );  

article_tags 表保存了 article 和 tag 之間的關系。每個 Article 可以對應到多個 Tag,反過來也是一樣。為簡單起見,我們就不創建 article 和 tag 表了,因此也就不用給 article_tags 加外鍵約束了。

接下來,我們創建一個存儲過程來把 Article 的 id 和 Tag 的 id 插入到 article_tags 表中,注意這個存儲過程***一條語句返回了表中的記錄總數:

  1. DELIMITER $$ 
  2.  
  3. CREATE PROCEDURE insert_article_tags(IN article_id INTIN tag_id INT
  4. BEGIN 
  5.  
  6.     DECLARE CONTINUE HANDLER FOR 1062 
  7.     SELECT CONCAT('duplicate keys (',article_id,',',tag_id,') found'AS msg; 
  8.  
  9.     -- insert a new record into article_tags 
  10.     INSERT INTO article_tags(article_id,tag_id) 
  11.     VALUES(article_id,tag_id); 
  12.  
  13.     -- return tag count for the article 
  14.     SELECT COUNT(*) FROM article_tags; 
  15. END $$  

然后,通過下面的命令,我們給 Id=1 的 Article 新增 Id 為1,2,3 的 Tag:

  1. CALL insert_article_tags(1,1); 
  2. CALL insert_article_tags(1,2); 
  3. CALL insert_article_tags(1,3);  

這之后,我們就要嘗試插入一條重復的記錄來看看錯誤處理器是否真的會被執行到。

  1. CALL insert_article_tags(1,3); 

 

 我們得到了一條錯誤信息。不過因為我們聲明的是 CONTINUE 類型的錯誤處理器,存儲過程會繼續往后執行,所以結果我們也得到了 article 的 tag 的總數。

如果我們把 CONTINUE 類型的錯誤處理器聲明成 EXIT,我們就只得到一個錯誤提示了。讓我們再編寫另外一個存儲過程:

  1. DELIMITER $$ 
  2.  
  3. CREATE PROCEDURE insert_article_tags_2(IN article_id INTIN tag_id INT
  4. BEGIN 
  5.  
  6.     DECLARE EXIT HANDLER FOR SQLEXCEPTION  
  7.     SELECT 'SQLException invoked'
  8.  
  9.     DECLARE EXIT HANDLER FOR 1062  
  10.         SELECT 'MySQL error code 1062 invoked'
  11.  
  12.     DECLARE EXIT HANDLER FOR SQLSTATE '23000' 
  13.     SELECT 'SQLSTATE 23000 invoked'
  14.  
  15.     -- insert a new record into article_tags 
  16.     INSERT INTO article_tags(article_id,tag_id) 
  17.        VALUES(article_id,tag_id); 
  18.  
  19.     -- return tag count for the article 
  20.     SELECT COUNT(*) FROM article_tags; 
  21. END $$  

***,我們可以嘗試新增一條重復主鍵的記錄看看效果:

  1. CALL insert_article_tags_2(1,3); 

 

 可以看到這次只輸出了錯誤信息就沒有繼續向下執行了。

錯誤處理器的優先級

當有多個錯誤處理器都滿足特定錯誤條件的時候,MySQL將按更明確者優先的原則決定優先級。

MySQL中的每個錯誤都會映射到一個特定的錯誤碼,因此錯誤碼是最明確的。一個 SQLSTATE 可以對應到多個 MySQL 錯誤碼,所以沒那么明確。SQLEXCEPTION 和 SQLWARNING 分別指代的是 SQLSTATES 中類型相近的一組值,所以它的明確性***。

基于錯誤處理器的優先級規則,MySQL 錯誤碼處理器,SQLSTATE 錯誤處理器 和 SQLEXCEPTION錯誤處理器順序上分別排在1、2、3位。

如果我們在 insert_article_tags_3 存儲過程里聲明3個錯誤處理器,像下面一樣:

  1. DELIMITER $$ 
  2.  
  3. CREATE PROCEDURE insert_article_tags_3(IN article_id INTIN tag_id INT
  4. BEGIN 
  5.  
  6.     DECLARE EXIT HANDLER FOR 1062 SELECT 'Duplicate keys error encountered'
  7.     DECLARE EXIT HANDLER FOR SQLEXCEPTION SELECT 'SQLException encountered'
  8.     DECLARE EXIT HANDLER FOR SQLSTATE '23000' SELECT 'SQLSTATE 23000'
  9.  
  10.     -- insert a new record into article_tags 
  11.     INSERT INTO article_tags(article_id,tag_id) 
  12.     VALUES(article_id,tag_id); 
  13.  
  14.     -- return tag count for the article 
  15.     SELECT COUNT(*) FROM article_tags; 
  16. END $$  

當我們通過下面的命令,試圖調用上面的存儲過程插入一條主鍵重復的記錄到article_tags表時:

  1. CALL insert_article_tags_3(1,3); 

 

 你會看到, MySQL錯誤碼綁定的那個處理器被調用了。

使用命名錯誤條件

我們先看一個錯誤處理器的聲明:

  1. DECLARE EXIT HANDLER FOR 1051 SELECT 'Please create table abc first'
  2. SELECT * FROM abc;  

1051 這個錯誤碼到底什么意思?想象一下如果你有很多的存儲過程,里面散布者這種數字,對于代碼維護來說應該就是噩夢了。

幸運的是,MySQL 為我們提供了一個 DECLARE CONDITION 語句來聲明一個命名錯誤條件,可以將上面的數字關聯為一個有意義的名字。

DECLARE CONDITION 語句的語法如下所示:

  1. DECLARE condition_name CONDITION FOR condition_value; 

condition_value 可以是一個類似 1051 的 MySQL 錯誤碼,或者一個 SQLSTATE 值,然后 condition_name 就可以代表condition_value 來使用了。

所以之前的代碼我們就可以改寫成下面的樣子:

  1. DECLARE table_not_found CONDITION for 1051; 
  2. DECLARE EXIT HANDLER FOR  table_not_found SELECT 'Please create table abc first'
  3. SELECT * FROM abc;  

這樣代碼的可讀性比之前明顯好多了。需要注意的是,要在存儲過程聲明一個命名條件的語句,則該語句必須出現在錯誤處理器或者游標聲明的前面。

一個在 handler 中實用的輔助函數

實際應用中,存儲過程中的錯誤被我們的錯誤處理器捕獲了之后,你如果還想用類似 mysql 命令行那樣的格式返回對應的錯誤,可以聲明一個這樣的函數:

  1. DELIMITER $$ 
  2. CREATE FUNCTION fn_get_error() 
  3. RETURNS VARCHAR(250) 
  4. BEGIN 
  5.     DECLARE code CHAR(5) DEFAULT '00000'
  6.     DECLARE msg TEXT; 
  7.     DECLARE errno INT
  8.      
  9.     GET DIAGNOSTICS CONDITION 1 code = RETURNED_SQLSTATE,  
  10.         errno = MYSQL_ERRNO, msg = MESSAGE_TEXT; 
  11.      
  12.     RETURN COALESCE(CONCAT("ERROR ", errno, " (", code, "): ", msg), '-'); 
  13. END$$  

那么在實際使用時,就可以在錯誤處理器中這樣用:

  1. DECLARE EXIT HANDLER FOR SQLEXCEPTION  
  2.      BEGIN  
  3.          ROLLBACK;  
  4.          SET ret = -9;  
  5.          SELECT ret AS 'ret', fn_get_error() AS 'err'
  6.      END;         
  7.      
  8.     DECLARE EXIT HANDLER FOR 1062 
  9.     BEGIN 
  10.         ROLLBACK;  
  11.          SET ret = -1;  
  12.          SELECT ret AS 'ret', fn_get_error() AS 'err'
  13.     END 

那么在有錯誤發生的時候,就可以得到如下的錯誤提示了:

 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2009-07-23 14:10:38

Hibernate J

2011-08-15 15:56:31

SQL Server

2010-05-31 16:57:09

2010-05-27 17:45:13

MySQL存儲過程

2023-12-26 22:05:53

并發代碼goroutines

2010-05-27 17:56:39

MySQL存儲過程

2023-10-28 16:30:19

Golang開發

2010-11-26 16:18:13

MySQL變量定義

2021-04-14 07:08:14

Nodejs錯誤處理

2011-04-11 17:28:50

oracle存儲select語句

2024-03-27 08:18:02

Spring映射HTML

2014-11-17 10:05:12

Go語言

2024-09-23 08:10:00

.NET開發

2023-10-26 12:05:14

Golang開發

2021-04-29 09:02:44

語言Go 處理

2022-08-26 16:28:41

MySQL存儲只讀語句

2010-04-15 16:54:31

Oracle存儲過程

2010-11-12 09:18:13

SQL Server存

2025-02-10 09:49:00

2017-12-19 07:09:22

數據中心合并IT
點贊
收藏

51CTO技術棧公眾號

一区二区在线视频观看| 午夜成年人在线免费视频| 日韩一区精品视频| 久久久国产精品亚洲一区| 日本wwwxx| 春暖花开亚洲一区二区三区| 亚洲美女偷拍久久| 鲁丝一区鲁丝二区鲁丝三区| 国产精品久久久久久久免费| 国产精品亚洲产品| 久久综合九色九九| 中文字幕在线看高清电影| 精品视频在线播放一区二区三区 | 亚洲欧美日韩一区二区三区四区| 91精品国产自产拍在线观看蜜| 日韩av在线免费观看一区| 免费成人黄色大片| 欧美黑人疯狂性受xxxxx野外| 亚洲精品综合在线| 图片区小说区区亚洲五月| 人成网站在线观看| 国产一区在线观看麻豆| 国产精品av在线| 久久夜靖品2区| 亚洲欧美综合国产精品一区| 亚洲网站视频福利| 亚洲一级av无码毛片精品 | 国产精选一区二区| 国产精品视频一二区| 国产亚洲精品v| 欧美日本亚洲视频| 亚洲区一区二区三| 成人羞羞动漫| 亚洲天堂第一页| 一起草在线视频| 91亚洲无吗| 日韩一区二区三区四区五区六区| 深夜黄色小视频| 日韩精品影院| 色综合久久久久| 欧美 日韩 国产 高清| 七七成人影院| 亚洲图片欧美视频| 91动漫在线看| jizz一区二区三区| 亚洲国产精品欧美一二99| 亚洲精品少妇一区二区| 91国内在线| 亚洲精品乱码久久久久久日本蜜臀| 亚洲一区二区在线观| wwwxxx在线观看| 国产精品久久久一区麻豆最新章节| 日韩中文一区| 91av资源在线| 1区2区3区国产精品| 一区二区三区四区五区视频 | 久久精品亚洲一区二区三区浴池| 久久精品日产第一区二区三区| 欧美在线精品一区二区三区| av网站一区二区三区| 国产午夜精品一区| 五月婷婷在线播放| 91免费看`日韩一区二区| 久久av二区| 国产在线观看免费网站| 国产精品青草久久| 强开小嫩苞一区二区三区网站| av毛片在线播放| 亚洲成人精品一区| 色欲av无码一区二区人妻| 欧美极品影院| 欧美精品高清视频| 中文字幕久久久久久久| 国产一区二区三区亚洲| 亚洲欧美日韩天堂一区二区| 欧美人与性囗牲恔配| 欧美电影一区| 欧美激情免费在线| 亚洲第一网站在线观看| 精品一区二区久久| 久久96国产精品久久99软件| 国产福利第一视频在线播放| 亚洲黄色免费网站| 九色在线视频观看| 日本久久一区| 亚洲高清色综合| 精品欧美一区二区久久久| 欧美电影免费观看高清| 午夜精品久久久99热福利| 国产一卡二卡三卡| 国产精品一区二区久激情瑜伽| 好看的日韩精品| 91亚洲欧美| 亚洲成人综合网站| 天天色综合社区| 亚洲欧美日本国产| 伊人久久大香线蕉av一区二区| 少妇被躁爽到高潮无码文| 最新日韩av| 91精品久久久久久| 四虎精品在线| 中文字幕在线一区免费| 黄色一级视频片| www.久久99| 亚洲人成电影在线播放| 麻豆疯狂做受xxxx高潮视频| 日韩一区精品视频| 精品乱码一区| 午夜av在线播放| 欧美亚洲图片小说| 97人妻精品一区二区三区免 | 久久视频在线播放| 亚洲自拍一区在线观看| 成人丝袜18视频在线观看| 视频一区视频二区视频三区视频四区国产 | 日韩免费高清视频网站| 亚洲日韩第一页| 日本a在线观看| 国产一区二区福利视频| 先锋影音网一区| av高清不卡| 欧美精品一区二区三| 成人在线观看高清| 免费成人你懂的| 日本婷婷久久久久久久久一区二区| 欧美黑人xx片| 日韩精品一区二区三区在线| 欧美做爰啪啪xxxⅹ性| 日韩电影在线看| 日本午夜精品电影| 中文字幕av一区二区三区佐山爱| 日韩av在线免费观看| 国产午夜精品一区二区理论影院 | 一区二区日本视频| 国产成人av一区二区三区| 国产成人无吗| 日韩一区二区三区高清免费看看| 欧美大片xxxx| 国内精品伊人久久久久av影院| 西游记1978| 日韩成人在线电影| 中文字幕欧美国内| 中文av免费观看| 亚洲国产成人私人影院tom | 国产成人小视频| 毛片在线视频观看| 日本精品一区二区三区在线观看视频| 日韩中文字幕在线| 一级二级三级视频| 亚洲人123区| 久久艹这里只有精品| 亚洲人metart人体| 97视频资源在线观看| 女同视频在线观看| 亚洲第一区第一页| 青青草av在线播放| 久久亚洲春色中文字幕久久久| 六月丁香激情网| 国产va免费精品观看精品视频| 日本精品在线视频 | 国产精品久久久久婷婷| 中文字幕亚洲乱码| 亚洲精彩视频| 国产嫩草一区二区三区在线观看| 激情国产在线| 这里只有精品视频在线| 国产美女免费看| 亚洲国产中文字幕在线视频综合 | 久久国产精品国产精品| 91精品一区国产高清在线gif | 99re国产在线播放| 老司机在线永久免费观看| 91麻豆精品国产91| 在线看成人av| 国产午夜三级一区二区三| 美女在线视频一区二区| 在线观看免费一区二区| 国模精品一区二区三区| av免费在线一区| 成年人精品视频| 午夜福利一区二区三区| 在线观看国产精品网站| 超碰在线国产97| 99re6这里只有精品视频在线观看| 成人在线观看黄| 我不卡影院28| 久久er99热精品一区二区三区 | 在线看国产日韩| 国产传媒免费在线观看| 不卡视频免费播放| 蜜臀av免费观看| 在线欧美三区| 亚洲人成网站在线观看播放| 国产精品毛片av| 国产精品扒开腿做| 污污影院在线观看| 夜夜嗨av一区二区三区四区| а√天堂资源在线| 日韩欧美一区二区在线| 国产一区二区播放| 久久久久国产成人精品亚洲午夜| 日韩av福利在线观看| 久久精品伊人| 国产美女永久无遮挡| 人人狠狠综合久久亚洲婷婷| 精品国产乱码久久久久久久软件| 韩国精品视频在线观看 | 久久精品美女视频网站 | 久久品道一品道久久精品| 97免费公开视频| 青椒成人免费视频| 丁香花在线影院观看在线播放| 色婷婷综合网| 日本中文不卡| 久久国产精品免费精品3p| 成人午夜激情网| 国外成人福利视频| 日韩暖暖在线视频| 午夜不卡影院| 国模吧一区二区| 色爱综合区网| 久久在线观看视频| 免费黄色在线观看| 国产亚洲精品高潮| 黄色小视频在线免费观看| 欧美精品一区二区高清在线观看 | 欧美少妇在线观看| 日韩精品水蜜桃| 涩涩涩999| 精品国产一区二区三区久久久蜜臀| 精品午夜一区二区| 精品欠久久久中文字幕加勒比| 91久久精品国产91久久性色tv| 伊人亚洲精品| 成人在线一区二区| www欧美在线观看| 国产精品嫩草影院久久久| 三上悠亚一区二区| 国产xxx69麻豆国语对白| 免费高潮视频95在线观看网站| 欧美精品第一页在线播放| 三级网站视频在在线播放| 欧美精品在线网站| 色网在线观看| 97色伦亚洲国产| 亚洲最新无码中文字幕久久| 91av在线网站| av电影一区| 国产精品高潮呻吟久久av黑人| 成人黄色免费短视频| 国产精品久久久久久久久免费看| 日本精品网站| 91麻豆国产精品| 亚洲精品一区二区三区在线| 国产伦精品一区二区三区在线 | 国产精品羞羞答答xxdd| 国产精久久久久| 99久久久久久| 亚洲成人网在线播放| 亚洲国产精品成人综合色在线婷婷 | 自拍亚洲一区| 午夜一区二区三视频在线观看| 99国产精品一区二区| 久久观看最新视频| 欧美日韩91| 2022亚洲天堂| 蜜桃av一区二区| 国产欧美精品一二三| 国产精品亚洲人在线观看| 在线看黄色的网站| 久久精品一区蜜桃臀影院| www.99re6| 亚洲一本大道在线| 欧美h在线观看| 正在播放一区二区| 日本高清视频www| 永久免费看mv网站入口亚洲| 国产三区在线观看| 57pao精品| 国产精品成人3p一区二区三区| 风间由美久久久| 精品免费视频| 欧美在线观看黄| 美女诱惑一区| 手机精品视频在线| 91麻豆精品在线观看| 777777国产7777777| 精品国产乱码久久久久酒店| 在线播放成人av| 亚洲国产私拍精品国模在线观看| www.在线播放| 91成人福利在线| 在线免费观看亚洲| 农村寡妇一区二区三区| 亚洲情侣在线| 中文字幕第80页| 成人深夜福利app| 亚洲一区电影在线观看| 午夜免费久久看| 国产男男gay体育生网站| 亚洲人成电影在线观看天堂色| 欧美日韩在线视频免费观看| 国产精品中文字幕在线| 日韩精品丝袜美腿| a天堂资源在线观看| 久久国产精品99久久人人澡| 日韩aaaaa| 亚洲激情一二三区| 中文字幕一区2区3区| 日韩精品极品视频免费观看| 黄网站免费在线播放| 国产成人精品在线观看| 超碰成人97| 天天综合五月天| 免费在线观看一区二区三区| 法国伦理少妇愉情| 亚洲国产美国国产综合一区二区| 亚洲天堂999| 国产一区二区免费| 亚洲成人人体| 久久另类ts人妖一区二区| 黄色精品免费| 秋霞午夜鲁丝一区二区| 中文字幕视频一区二区三区久| 69视频免费看| 亚洲美女av网站| 黄色软件视频在线观看| av一区和二区| 欧美人成在线| 能看毛片的网站| 亚洲三级免费观看| 在线免费观看av片| 中文字幕av一区二区三区谷原希美| 二区三区不卡| 欧美一区2区三区4区公司二百| 国产亚洲一区在线| 国产精品无码永久免费不卡| 婷婷综合久久一区二区三区| 蜜臀久久久久久999| 欧美黑人视频一区| 成人午夜网址| 成人在线观看你懂的| 成人动漫av在线| 国产超碰人人爽人人做人人爱| 欧美精品一区二区三区在线播放| 人人澡人人添人人爽一区二区| av资源一区二区| 尤物精品在线| 午夜av免费看| 色先锋久久av资源部| 成人在线视频成人| 国产日韩av高清| 欧美一区久久| 亚洲欧美综合视频| 欧美日韩国产一中文字不卡| 嫩草研究院在线观看| 国产精品免费在线免费| 91青青国产在线观看精品| 午夜视频在线观| 亚洲在线视频网站| 日本xxxxwww| 日韩av电影院| 久久亚洲成人| 韩国三级在线看| 午夜欧美在线一二页| 国产在线视频资源| 91精品免费视频| 韩国一区二区三区在线观看| 五十路六十路七十路熟婆| 在线视频中文字幕一区二区| 日本不卡不卡| 国产伦精品一区二区三区视频免费| 国产亚洲成人一区| 欧美性生交大片| 精品欧美一区二区三区精品久久| 玖玖在线播放| 亚洲成人在线视频网站| 国产一区二区在线视频| 欧美亚韩一区二区三区| 国产亚洲激情视频在线| 天堂av一区| 青青在线免费观看视频| ㊣最新国产の精品bt伙计久久| 刘亦菲久久免费一区二区| 国产成人精品免费视频| 亚洲国产日韩欧美在线| 18禁裸乳无遮挡啪啪无码免费| 欧美精品丝袜中出| 女人让男人操自己视频在线观看 | 久久精品丝袜高跟鞋| 久久99精品一区二区三区三区| 久久久久亚洲av无码专区| 夜夜嗨av一区二区三区免费区| 天堂va在线高清一区| 不要播放器的av网站| 亚洲一区二区三区激情| 懂色av中文在线| 久久av一区二区三区漫画| 国产高清在线精品| 亚洲精品一区二三区|