午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > MySQL 觸發(fā)器的使用及需要注意的地方

MySQL 觸發(fā)器的使用及需要注意的地方

熱門標簽:云南語音外呼系統(tǒng)平臺 福州呼叫中心外呼系統(tǒng)哪家好 常州電銷外呼系統(tǒng)一般多少錢 400電話鄭州申請 北京人工外呼系統(tǒng)價錢 天智外呼系統(tǒng) 沃克斯電梯外呼線路圖 房產(chǎn)智能外呼系統(tǒng)品牌 地圖標注被騙三百怎么辦

關(guān)于觸發(fā)器

現(xiàn)實開發(fā)中我們經(jīng)常會遇到這種情況,比如添加、刪除和修改信息的時候需要記錄日志,我們就要在完成常規(guī)的數(shù)據(jù)庫邏輯操作之后再去寫入日志表,這樣變成了兩步操作,更復(fù)雜了。

又比如刪除一個人員信息的時候,需要將他的購物記錄、收貨地址、收藏夾等都刪了,這個連續(xù)的操作容易出錯,一致性和完整性不好保證。這時候就要使用觸發(fā)器,既可以免去一堆的業(yè)務(wù)邏輯代碼,又能更好的保證數(shù)據(jù)完整性。

觸發(fā)器(trigger)是一種與表有關(guān)的數(shù)據(jù)庫對象:在滿足定義條件時觸發(fā)某種操作,并執(zhí)行觸發(fā)器中定義的語句集合。觸發(fā)器的這種特性可以協(xié)助應(yīng)用在數(shù)據(jù)庫端保證數(shù)據(jù)的完整性。

它是一種與表事件相關(guān)的特殊的存儲過程,當(dāng)對一個表進行操作( insert,delete, update)時就會激活執(zhí)行。

觸發(fā)器的使用

創(chuàng)建觸發(fā)器

創(chuàng)建觸發(fā)器的語法如下:

CREATE TRIGGER trigger_name trigger_time trigger_event ON t_name FOR EACH ROW trigger_stmt

說明:

trigger_name:觸發(fā)器名稱

tirgger_time:觸發(fā)執(zhí)行時間點,數(shù)據(jù)操作前(BEFORE) 或者 數(shù)據(jù)操作后(AFTER)

trigger_event:觸發(fā)事件,增(INSERT)、刪(DELETE)、改(UPDATE)

t_name:指的是在 t_name 這張表上建立觸發(fā)器

trigger_stmt:觸發(fā)器的程序體,可以是一條SQL語句或者是用BEGIN和END包含的多條語句

觸發(fā)器只能創(chuàng)建在永久表(Permanent)上,不能創(chuàng)建在臨時表(Temporary)上

FOR EACH ROW 固定表達式,表示任何一條記錄上的操作滿足觸發(fā)事件都會觸發(fā)該觸發(fā)器

tirgger_time有兩種類型,trigger_event有三種類型,所以他們一共有6種組合:BEFORE INSERT,BEFORE DELETE,BEFORE UPDATE,AFTER INSERT,AFTER DELETE,AFTER UPDATE

示例(先創(chuàng)建一個日志表,用于觸發(fā)器觸發(fā)時候填入值):

/*先創(chuàng)建一個日志表,用于觸發(fā)器觸發(fā)時候填入值*/
mysql> DROP TABLE IF EXISTS `TriggerLog`;
Query OK, 0 rows affected

mysql> CREATE TABLE `TriggerLog`
(
  `id` INT auto_increment PRIMARY KEY,
  `trigger_time` VARCHAR(30),
  `trigger_event` VARCHAR(30),
  `memo` VARCHAR(200)
);
Query OK, 0 rows affected

Insert類型觸發(fā)器:

mysql>
/*這邊聲明SQL腳本的結(jié)束符為// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_insert;
CREATE TRIGGER trig_after_insert AFTER INSERT ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','insert',concat('new student info,id:',cast(new.studentid as char)));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL腳本的結(jié)束符為; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*插入一條數(shù)據(jù) */
insert into students(studentname,score,classid) values('trigger1',100,0);
Query OK, 1 row affected


mysql>
/*查詢?nèi)罩颈砜词欠裼杏|發(fā)寫入 */
select * from `TriggerLog`;
+----+--------------+---------------+------------------------+
| id | trigger_time | trigger_event | memo          |
+----+--------------+---------------+------------------------+
| 1 | after    | insert    | new student info,id:21 |
+----+--------------+---------------+------------------------+
1 row in set

Update類型觸發(fā)器:

mysql>
/*這邊聲明SQL腳本的結(jié)束符為// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_update;
CREATE TRIGGER trig_after_update AFTER UPDATE ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('update student info,id:',cast(new.studentid as char)));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL腳本的結(jié)束符為; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*更新數(shù)據(jù) */
update students set score=99 where studentname='trigger1';
Query OK, 1 row affected
Rows matched: 1 Changed: 1 Warnings: 0

mysql>
/*查詢?nèi)罩颈砜词欠窀碌臅r候有觸發(fā)寫入 */
select * from `TriggerLog`;
+----+--------------+---------------+---------------------------+
| id | trigger_time | trigger_event | memo           |
+----+--------------+---------------+---------------------------+
| 1 | after    | insert    | new student info,id:21  |
| 2 | after    | update    | update student info,id:21 |
+----+--------------+---------------+---------------------------+
2 rows in set

Delete類型觸發(fā)器:

mysql>
/*這邊聲明SQL腳本的結(jié)束符為// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_delete;
CREATE TRIGGER trig_after_delete AFTER DELETE ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('delete student info,id:',cast(old.studentid as char)));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL腳本的結(jié)束符為; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/* 刪除數(shù)據(jù) */
delete from students where studentid=21;
Query OK, 1 row affected

mysql>
/*查詢?nèi)罩究磩h除是否有觸發(fā)寫入*/
select * from `TriggerLog`;
+----+--------------+---------------+---------------------------+
| id | trigger_time | trigger_event | memo           |
+----+--------------+---------------+---------------------------+
| 1 | after    | insert    | new student info,id:21  |
| 2 | after    | update    | update student info,id:21 |
| 3 | after    | update    | delete student info,id:21 |
+----+--------------+---------------+---------------------------+
3 rows in set

查看觸發(fā)器

查看全部觸發(fā)器

show triggers; --語法 
mysql> show triggers;
+-------------------+--------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+---------+--------------------------------------------+----------------+----------------------+----------------------+--------------------+
| Trigger      | Event | Table  | Statement                                                                             | Timing | Created | sql_mode                  | Definer    | character_set_client | collation_connection | Database Collation |
+-------------------+--------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+---------+--------------------------------------------+----------------+----------------------+----------------------+--------------------+
| trig_after_insert | INSERT | students | BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','insert',concat('new student info,id:',cast(new.studentid as char)));
END  | AFTER | NULL  | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION | root@localhost | utf8         | utf8_general_ci   | latin1_swedish_ci |
| trig_after_update | UPDATE | students | BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('update student info,id:',cast(new.studentid as char)));
END | AFTER | NULL  | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION | root@localhost | utf8         | utf8_general_ci   | latin1_swedish_ci |
| trig_after_delete | DELETE | students | BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('delete student info,id:',cast(old.studentid as char)));
END | AFTER | NULL  | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION | root@localhost | utf8         | utf8_general_ci   | latin1_swedish_ci |
+-------------------+--------+----------+--------------------------------------------------------------------------------------------------------------------------------------------------------------------+--------+---------+--------------------------------------------+----------------+----------------------+----------------------+--------------------+
3 rows in set

查看觸發(fā)器的創(chuàng)建語句

show create trigger trigger_name;  --語法
mysql> show create trigger trig_after_insert;
+-------------------+--------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+
| Trigger      | sql_mode                  | SQL Original Statement                                                                                                                      | character_set_client | collation_connection | Database Collation |
+-------------------+--------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+
| trig_after_insert | STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION | CREATE DEFINER=`root`@`localhost` TRIGGER trig_after_insert AFTER INSERT ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','insert',concat('new student info,id:',cast(new.studentid as char)));
END | utf8         | utf8_general_ci   | latin1_swedish_ci |
+-------------------+--------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+----------------------+----------------------+--------------------+
1 row in set

刪除觸發(fā)器

drop trigger trigger_name;  --語法 
mysql> drop trigger trig_after_insert;
Query OK, 0 rows affected
 
mysql> show create trigger trig_after_insert;
1360 - Trigger does not exist 

使用時的注意點

NEW / OLD的使用區(qū)別

觸發(fā)器針對的是數(shù)據(jù)庫中的每一行記錄,每行數(shù)據(jù)在操作前后都會有一個對應(yīng)的狀態(tài),觸發(fā)器將沒有操作之前的狀態(tài)保存到 old 關(guān)鍵字中,將操作后的狀態(tài)保存到 new 中

 new.cname --新增行(或修改前的行)的某列數(shù)據(jù)
 old.cname --刪除行(或修改后的行)的某列數(shù)據(jù)

需要注意的是,old 和 new 不是所有觸發(fā)器都有

觸發(fā)器類型 new和old的使用
INSERT型觸發(fā)器 沒有 old,只有 new,new 表示將要(插入前)或者已經(jīng)增加(插入后)的數(shù)據(jù)
UPDATE型觸發(fā)器 既有 old 也有 new,old 表示更新之前的數(shù)據(jù),new 表示更新之后的數(shù)據(jù)
DELETE型觸發(fā)器 沒有 new,只有 old,old 表示將要(刪除前)或者已經(jīng)被刪除(刪除后)的數(shù)據(jù)

其實我們上面已經(jīng)用過 new/old 來創(chuàng)建觸發(fā)器并獲取數(shù)據(jù),我們根據(jù)這個表格重新來修改下那個更新觸發(fā)器(trig_after_update),輸出修改前和修改后的內(nèi)容比較:

mysql>
/*這邊聲明SQL腳本的結(jié)束符為// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_update;
CREATE TRIGGER trig_after_update AFTER UPDATE ON students FOR EACH ROW
BEGIN
 insert into `TriggerLog`(`trigger_time`,`trigger_event`,`memo`) values ('after','update',concat('from:',old.studentname,',',old.score,' ','to:',new.studentname,',',new.score));
END //
Query OK, 0 rows affected

mysql>
/*重置SQL腳本的結(jié)束符為; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*更新成績和名稱 */
update students set score=106,studentname='trigger2' where studentid=17;
Query OK, 1 row affected
Rows matched: 1 Changed: 1 Warnings: 0

mysql>
/*根據(jù)old和new 對比更新前后的值 */
select * from `TriggerLog`;
+----+--------------+---------------+--------------------------------------+
| id | trigger_time | trigger_event | memo                 |
+----+--------------+---------------+--------------------------------------+
| 1 | after    | insert    | new student info,id:21        |
| 2 | after    | update    | update student info,id:21      |
| 3 | after    | update    | delete student info,id:21      |
| 4 | after    | update    | from:test2,101.00 to:trigger2,106.00 |
+----+--------------+---------------+--------------------------------------+
4 rows in set

無法觸發(fā)對同表的修改

MySQL 的觸發(fā)器中不能對本表進行 insert、update 和 delete 操作,否則會報錯

mysql>
/*這邊聲明SQL腳本的結(jié)束符為// */
DELIMITER //
DROP TRIGGER IF EXISTS trig_after_insert;
CREATE TRIGGER trig_after_insert AFTER INSERT ON students FOR EACH ROW
BEGIN
 update students set score = score+1 where studentid= new.studentid;
END //
Query OK, 0 rows affected

mysql>
/*重置SQL腳本的結(jié)束符為; */
DELIMITER ;
Query OK, 0 rows affected

mysql>
/*插入一條數(shù)據(jù)之后因為觸發(fā)了對本表的修改,所以報錯了 */
insert into students(studentname,score,classid) values('trigger2',101,0);
1442 - Can't update table 'students' in stored function/trigger because it is already used by statement which invoked this stored function/trigger.

小結(jié)

1、觸發(fā)器可以通過數(shù)據(jù)庫中的關(guān)聯(lián)表實現(xiàn)級聯(lián)更改,即一張表數(shù)據(jù)的改變會影響其他表的數(shù)據(jù),如數(shù)據(jù)修改,數(shù)據(jù)統(tǒng)計,數(shù)據(jù)復(fù)制等。
2、可以保證數(shù)據(jù)安全,并進行安全校驗,限制用戶具有操作數(shù)據(jù)庫的某種權(quán)利。
3、可以對復(fù)雜邏輯的實現(xiàn)進行數(shù)據(jù)完整性檢查和約束。
4、使用觸發(fā)器的要應(yīng)需而用,如果過分依賴觸發(fā)器,會影響數(shù)據(jù)庫的結(jié)構(gòu),增加數(shù)據(jù)庫的執(zhí)行和維護成本。
5、觸發(fā)器有BEFORE觸發(fā)器和AFTER觸發(fā)器的卻別,所以它的執(zhí)行步驟是先執(zhí)行 BEFORE觸發(fā)器,再執(zhí)行業(yè)務(wù)腳本,最后執(zhí)行AFTER觸發(fā)器。需要注意的是 某一個步驟錯誤后就不再執(zhí)行了, 如果是事務(wù)表,會被回滾,如果是非事務(wù)表,那么就無法回滾了,數(shù)據(jù)可能有不一致性。

觸發(fā)器的兩種限制

1、觸發(fā)程序不能調(diào)用將數(shù)據(jù)返回客戶端的存儲程序,也不能使用采用CALL語句的動態(tài)SQL語句,但是允許存儲程序通過參數(shù)將數(shù)據(jù)返回觸發(fā)程序,也就是存儲過程或者函數(shù)通過OUT或者INOUT類型的參數(shù)將數(shù)據(jù)返回觸發(fā)器是可以的,但是不能調(diào)用直接返回數(shù)據(jù)的過程。
2、不能再觸發(fā)器中使用以顯示或隱式方式開始或結(jié)束事務(wù)的語句,如START TRANS-ACTION,COMMIT或ROLLBACK。

以上就是MySQL 觸發(fā)器的使用及需要注意的地方的詳細內(nèi)容,更多關(guān)于MySQL 觸發(fā)器的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • mysql觸發(fā)器trigger實例詳解
  • MySQL中觸發(fā)器和游標的介紹與使用
  • MySQL 觸發(fā)器的使用和理解
  • MySQL中使用游標觸發(fā)器的方法
  • MySQL觸發(fā)器的使用場景及方法實例
  • 詳解MySQL數(shù)據(jù)庫之觸發(fā)器
  • 淺談MySql 視圖、觸發(fā)器以及存儲過程
  • mysql 觸發(fā)器創(chuàng)建與使用方法示例
  • MySQL觸發(fā)器基本用法詳解【創(chuàng)建、查看、刪除等】
  • MySQL觸發(fā)器的使用

標簽:黔東 沈陽 拉薩 沈陽 徐州 鹽城 移動 珠海

巨人網(wǎng)絡(luò)通訊聲明:本文標題《MySQL 觸發(fā)器的使用及需要注意的地方》,本文關(guān)鍵詞  MySQL,觸發(fā)器,的,使用,及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL 觸發(fā)器的使用及需要注意的地方》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL 觸發(fā)器的使用及需要注意的地方的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    中文字幕久久一区| 欧美色欧美亚洲高清在线视频| 午夜精品久久久久久久白皮肤 | 欧美大波大乳巨大乳| 久久久亚洲午夜电影| 欧美黑人国产人伦爽爽爽| 天天躁夜夜躁狠狠是什么心态| 亚洲一区二区在线免费观看视频| 亚洲制服欧美久久| 日韩在线视频免费| 日韩在线一区二区三区免费视频| 天天做天天干天天操| 99视频精品在线| 精品产品国产在线不卡| 成人亚洲欧美一区二区三区| 日本免费不卡一区二区| 白白色 亚洲乱淫| 99伊人久久| 免费国产黄色片| 久久乐国产精品| 欧美在线观看不卡| 日韩亚洲欧美一区| 亚洲免费看av| 亚洲精品伦理在线| 老司机激情视频| 久久亚洲精精品中文字幕早川悠里| 香港三级日本三级a视频| 91精东传媒理伦片在线观看| 成人免费av在线| 一区二区三区日韩精品视频| 日韩福利在线| 伊人影院中文字幕| 欧美高跟鞋交xxxxxhd| 国产亚洲色婷婷久久99精品| 精品亚洲一区二区三区在线观看| 视频区 图片区 小说区| 婷婷成人激情在线网| 国产日本在线播放| 久久久999精品免费| 欧美精品卡一卡二| 国产欧美日韩久久| www成人免费| 国产片一区二区三区| 菠萝蜜视频在线观看入口| 国产精品美女久久久久久久网站| 国产精品久久久久久久精| 91精品免费视频| 久久久99免费| 久久久久亚洲AV成人无在| 国产91色在线免费| 久久精品视频在线看| 国产精品 日产精品 欧美精品| 亚洲一区二区三区涩| 国产精品网曝门| 粗大的内捧猛烈进出视频| 国产一区二区三区精品久久久| 波多野结衣人妻| 日本精品视频在线观看| 91国内精品视频| 国产精品女人久久久久久| 亚洲欧美另类日本| 中日韩美女免费视频网址在线观看| 精品人体无码一区二区三区| 亚洲欧美激情精品一区二区| 久久久久亚洲av片无码| 熟女高潮一区二区三区| 一区二区三区四区在线免费观看 | 国产精品久久久久桃色tv| 日韩精品免费一区| 亚洲影视在线观看| 欧美日韩第二页| 在线欧美日韩国产| 一级黄色毛毛片| 亚洲男子天堂网| 国产一级aa大片毛片| 欧美国产日本高清在线| 免费的黄色av| 91麻豆成人精品国产免费网站| 日韩成人在线电影网| 久久亚洲精品国产| 久久久综合av| 日韩精品视频网| 懂色av一区二区三区在线播放| 成人永久aaa| 免费av网址在线| 在线观看91视频| 视频免费在线观看| 欧美精品一区视频| 91视频综合网| 五月天丁香花婷婷| 亚洲大片一区二区三区| 国产精品一区二区无码对白| 亚洲人成欧美中文字幕| 国产微拍精品一区| 98视频在线噜噜噜国产| 精品国自产在线观看| 91久久精品久久国产性色也91| 美日韩一级片在线观看| 亚洲 日韩 国产第一区| 亚洲三级在线播放| 毛片毛片毛片毛片毛| 亚洲黄色免费三级| 无码人妻一区二区三区一| 亚洲一区二区三区激情| 美国一级黄色录像| 欧美性做爰毛片| 成人动漫av在线| 日韩精品在线视频免费观看| 欧美日韩国产高清一区| 成年人视频在线免费看| 国产精品久久久久国产a级| 97se狠狠狠综合亚洲狠狠| 成人免费在线小视频| 精品日韩欧美在线| 久久精品2019中文字幕| 精品久久99ma| 天天天天天天天天操| 久久国产精品久久久久久| 久久av中文字幕片| 中文字幕一区二区三区乱码| 欧美日韩国产小视频在线观看| 在线观看免费国产视频| 精品乱码一区| 色哟哟一区二区在线观看| 欧美 日韩 国产 一区二区三区| 日韩av电影免费观看高清| 国产精品亚洲视频| 亚洲欧美日韩中文字幕在线观看| 久久午夜a级毛片| 成人一区二区三区视频在线观看| 中文字幕18页| 国产成人精品久久二区二区91| 欧美经典三级视频一区二区三区| 国产探花视频在线播放| 99在线免费观看视频| 精品久久久在线观看| 91久久国产综合久久91| 中文字幕中文字幕一区三区| 精品成人免费观看| 久久精品国产99国产精品| 亚洲免费在线播放视频| 18性欧美xxxⅹ性满足| 亚洲欧洲日本在线| 97久久久久久久| 超碰97在线看| 亚洲欧美国产va在线影院| 国产91露脸合集magnet| av网页在线观看| 国产精品国产福利国产秒拍| 亚洲欧美一区二区三区国产精品| www亚洲视频| 国产精品12345| 国产精品99久久久久久有的能看| 91小视频网站| 欧美丰满少妇xxxxx| 国产精品三级av| 日韩精品在线观看免费| 日韩黄色片在线| 综合色天天鬼久久鬼色| 午夜视频网站在线观看| 国产综合av在线| 久久久999国产精品| 椎名由奈av一区二区三区| 日韩欧美三级视频| 久久人人爽人人爽人人av| 在线播放日韩专区| 国产欧美日韩三级| 伊人成年综合网| 91淫黄看大片| 91精品久久久久久久久青青| 欧美日韩精品一区视频| 亚洲视频999| 国产精一区二区三区| 国产99久久精品一区二区永久免费 | 国产美女视频免费看| 2019中文在线观看| 亚洲成人精品一区| 人妻夜夜爽天天爽| 国内精品国产三级国产aⅴ久| 2024亚洲男人天堂| 色综合一区二区三区| 久久一区二区三区超碰国产精品| 九九热视频免费| 国产亚洲自拍偷拍| 亚洲黄色片网站| 久久久久国产免费免费| 久久综合色综合| 国产亚洲综合视频| 国产精品第一区| 337p亚洲精品色噜噜| 国产中文字幕精品| 日本特黄特色aaa大片免费| 日韩在线观看a| 国产精品免费福利| 日韩欧美aaaaaa| 美国欧美日韩国产在线播放| 青青草手机在线观看| 亚洲国产精品久久久久婷蜜芽| 国产91色在线|免| 在线观看亚洲a| 另类综合日韩欧美亚洲| 伊人国产在线观看| 久草青青在线观看| 欧美国产综合视频| 狠狠躁夜夜躁人人躁婷婷91| 中文有码在线播放| 久久久久无码国产精品一区| 欧美香蕉大胸在线视频观看 | 欧美电影一区二区三区| 国产在线乱码一区二区三区| 日韩精品一区二区不卡| 国产a√精品区二区三区四区| 久久综合久久网| 精品乱码一区二区三区| 久久天堂av综合合色| 亚洲国产精品视频| 久久精品国产在热久久| 日本一级黄色录像| 波多野结衣办公室33分钟| 黄色免费视频大全| 久久99精品国产99久久| 欧美有码在线观看| 色偷偷综合社区| 日韩三级高清在线| 精品欧美aⅴ在线网站| 日韩美女视频一区二区| 亚洲狼人综合网| 日日夜夜狠狠操| 国产大学生自拍| fc2成人免费视频| 婷婷视频在线播放| 国产高清在线精品一区二区三区| 久久人人97超碰精品888| 亚洲欧洲美洲在线综合| 91精品国产免费| 精品日本高清在线播放 | 亚洲激情五月婷婷| 久久久精品欧美丰满| 国产黄色成人av| 国产熟女一区二区三区五月婷| 午夜偷拍福利视频| 992在线观看| 国产激情第一页| jizz欧美性11| 黄色片一级视频| www.国产在线视频| 一区二区三区四区在线视频| 国内一区二区三区在线视频| 欧美一级片免费在线| 欧美极品美女电影一区| 中文字幕亚洲情99在线| 亚洲国产私拍精品国模在线观看| 欧美亚洲一区二区在线| 亚洲精品国产成人久久av盗摄| 国产精品色一区二区三区| 成人在线综合网| 国产成人自拍网| 国产一区二区在线观看免费| 久久精品国产亚洲一区二区三区| 亚洲欧美一区二区三| 国产高中女学生第一次| 在线观看免费观看在线| 中文字幕乱码在线观看| 中文字幕乱码人妻无码久久| 无码人妻久久一区二区三区| 少妇一级淫片免费放中国| 亚洲少妇xxx| 国产一区二区三区视频播放| 日本人亚洲人jjzzjjz| 91资源在线播放| 中文乱码字幕高清一区二区| 国产一二三区精品| 一区二区三区影视| 免费人成在线观看| 欧美a∨亚洲欧美亚洲| 一级片视频在线观看| 啪啪小视频网站| 中文在线免费看视频| 午夜精品久久久久久久96蜜桃| 精品久久人妻av中文字幕| 嫩草影院一区二区| 处破女av一区二区| 中文字幕第一页久久| 亚洲激情校园春色| 在线亚洲高清视频| 欧美日韩一级黄| 日韩欧美一区二区免费| 亚洲欧美一区二区三区久久| 久久精品免费播放| 性色av一区二区咪爱| 国产精品久久久久7777婷婷| 豆国产97在线| 污视频在线免费观看一区二区三区 | 免费视频最近日韩| 国产成人自拍网| 国产欧美精品一区二区色综合 | 国产美女精品久久久| 中文字幕一区二区三区四区五区| 久久手机在线视频| 中文字幕精品一区二区三区在线| 国产精品边吃奶边做爽| 99久久婷婷国产综合| 中文字幕av第一页| 久久久久久夜| 99视频精品免费视频| 伊人色综合久久天天| 欧美日韩国产成人在线免费| 在线播放日韩专区| 国产mv免费观看入口亚洲| 久久99精品久久久久久秒播放器| 中国老女人av| 手机免费av片| 毛片aaaaaa| 一本色道久久综合亚洲| 狠狠色综合日日| 中文字幕一区二区三区视频| 欧美日韩情趣电影| 久久久www成人免费精品张筱雨| 国产精品揄拍一区二区| 午夜免费电影一区在线观看| 欧美激情第3页| 日韩在线观看视频一区二区| aaa一区二区| 国产不卡在线一区| 亚洲第一综合色| 亚洲成人999| 久久99热精品| 久久精品日产第一区二区三区乱码 | 亚洲精品国产成人久久av盗摄 | 国产91在线播放九色快色| 日韩成人在线资源| 五月激情婷婷在线| 九热这里只有精品| 久久免费黄色| 亚洲欧美一区二区视频| 亚洲精品一区二区精华| 欧洲成人午夜免费大片| 色婷婷精品国产一区二区三区| 中文字幕成人在线视频| 日本熟妇乱子伦xxxx| 久久精品国产一区二区三| 亚洲国产精品久久人人爱蜜臀| 亚洲天堂av综合网| 亚洲已满18点击进入在线看片| 欧美一区二区中文字幕| 国产精品99久久久久久成人| 婷婷色在线观看| 一区二区三区四区不卡在线 | 亚洲成年人在线观看| 国产一卡二卡三卡| 国产一区二区福利视频| 色一情一乱一乱一91av| 久久久久久久久久久成人| 999日本视频| 亚洲精品中文字幕无码蜜桃| 老司机精品免费视频| 天天爽夜夜爽夜夜爽| 亚洲国产精品一区二区www| 日韩在线视频中文字幕| 免费国产一区二区| 国产jk精品白丝av在线观看| 亚洲av成人精品毛片| 亚洲乱码一区二区三区在线观看| 精品久久久999| 国产又大又长又粗又黄| 亚洲一级片在线播放| 久久免费高清| 欧美伊人久久久久久久久影院| 欧美一级片一区| 粗暴91大变态调教| 在线观看国产精品视频| 中文字幕亚洲区| 亚洲色图综合久久| 亚洲欧洲日韩精品| 顶级黑人搡bbw搡bbbb搡| 国产不卡高清在线观看视频| 亚洲国产91精品在线观看| 91精品婷婷国产综合久久蝌蚪| 成人不卡免费视频| 99视频免费看| 亚洲图片欧美视频| 日产精品久久久一区二区福利| 内射国产内射夫妻免费频道| 久久国产黄色片| 国产精品传媒在线| 裸体女人亚洲精品一区| 成人一级生活片| 中文字字幕在线中文| 国产欧美一二三区| 久久久精品一区二区| 野外做受又硬又粗又大视频√| 欧美卡一卡二卡三| 久久免费精品国产久精品久久久久| 一夜七次郎国产精品亚洲| 伊人久久大香线蕉av一区| 18精品爽视频在线观看| 久久综合九色综合97婷婷| 亚洲女人被黑人巨大进入| 一级特黄录像免费播放全99| 劲爆欧美第一页| 亚洲欧美中日韩| 欧美专区第一页| 看欧美ab黄色大片视频免费| 国产精品一区二区免费视频| 色999日韩国产欧美一区二区| 97超碰资源| 国产第一页浮力| 国产精品久久二区二区| 日韩av免费一区| 久久久久9999|