久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

mysql雙游標嵌套循環方式

瀏覽:9日期:2023-07-05 19:48:16
目錄mysql雙游標嵌套循環mysql游標與嵌套循環游標嵌套遍歷測試總結mysql雙游標嵌套循環

系統要上線新功能,引入了BPMN流程引擎,引入該引擎后就會涉及到歷史數據處理問題,因為系統已經生成了上千條業務數據,由于不是靠BPMN引擎流轉的,所以需要將業務數據和流程引擎關聯起來,有多少條在執行的業務數據,就生成多少條流程實例,我們的流程引擎使用的是activiti流程引擎框架;

其中一塊的歷史數據處理是要查詢出符合條件的歷史數據,然后遍歷循環業務,業務數據中有個處理人的字段是多人的,要把這個多人的以逗號分隔開,有幾人再次循環幾次;

廢話不多說,直接上代碼:

delimiter //drop procedure if exists procedure_test;create procedure procedure_test()begin?? ?declare count_ int default 0;?? ?declare requirementCount_ int default 1;?? ?declare assigineeCount_ int default 1;?? ?declare result_ int default 0;?? ?declare startUserId_ int ;?? ?declare runTaskAssignee int ;?? ?declare businessMainDataId int;?? ?declare businessCode varchar(10);?? ?declare users varchar(250);?? ?declare process_serial_number int default 0;?? ?-- 創建游標1?? ?declare cursor_test1 cursor for select o.commituserId,o.id,o.code from rp_original_requirement o where o.status = 1 and o.currentNode = 16;?? ?-- 創建游標2 ,這個游標的創建使用了:將數據庫內某個字段以逗號分隔的列,拆成一個數據列表,這樣游標2就可以遍歷執行這個數據集了?? ?-- 其中語句:select (id-1) as id from rp_nonstandard_approve c order by id asc limit 21 ?是要查出一個從0開始的遞增的連續數字,rp_nonstandard_approve 的主鍵id剛好是自增的主鍵,limit 21 是因為a.approveHandlers字段最多存20個人,所以這里要大于20;?? ?declare cursor_test2 cursor for select substring_index(substring_index(a.approveHandlers,',',d.id+1),',',-1) as assignee from rp_nonstandard_approve a join ( select (id-1) as id from rp_nonstandard_approve c order by id asc limit 21 ) d on d.id<(length(a.approveHandlers)-length(replace(a.approveHandlers,',',''))+1) where a.status = 1 and a.requirementID=businessMainDataId ;?? ?-- 游標循環結束?? ?declare exit handler for not found close cursor_test1 ;?? ?select count(1) into requirementCount_ ?from ?rp_original_requirement o where o.status = 1 and o.currentNode = 16;?? ?select p.id_ into @procDefId from act_re_prodef p left join act_re_deployment ard on p.deployment_id_= ard.id_?? ?where p.key_='nonstandardProcess' order by deploy_time_ desc limit 1;?? ?set @i=1;?? ?-- 開啟游標,調用開啟游標時才會執行對應游標的查詢方法?? ?open cursor_test1 ;?? ?while @i<=requirementCount_ ?do?? ??? ?-- 將游標中的值賦值給申明的變量,順序要和游標定義內的一致;?? ??? ?fetch cursor_test1 into startUserId_ ,businessMainDataId ,businessCode ;?? ??? ?set process_serial_number = process_serial_number + 1;?? ??? ?set @processInstanceName = concat('NSP',date_formart(now(),'%Y%m%d%H%i%s'),lpad(process_serial_number,6,0));?? ??? ?set @mainProcessId=repalce(uuid(),'-','');?? ??? ?set @startUserId= startUserId_ ;?? ??? ?-- 運行時實例?? ??? ?insert into act_ru_execution (id_, rev_, proc_inst_id_, business_key_, parent_id_, proc_def_id_, super_exec_, root_proc_inst_id_, act_id_, is_active_, is_concurrent_, is_scope_, is_event_scope_, is_mi_root_, suspension_state_, cached_ent_state_, tenant_id_, name_, start_time_, start_user_id_, lock_time_, is_count_enable_, evt_subscr_count_, task_count_, job_count_, timer_job_count_, susp_job_count_, deadletter_job_count_, var_count_, id_link_count_ )?? ??? ?values (@mainProcessId,1,@mainProcessId,null,null,@procDefId,null,@mainProcessId,null,1,0,1,0,0,1,null,'',@processInstanceName ,sysdate(),@startUserId,null,0,0,0,0,0,0,0,0,0);?? ?set @middleProcessId = replace(uuid(),'-','');?? ?set @middleProcessActKey = 'nonStandardApprove';?? ?insert into act_ru_execution (id_, rev_, proc_inst_id_, business_key_, parent_id_, proc_def_id_, super_exec_, root_proc_inst_id_, act_id_, is_active_, is_concurrent_, is_scope_, is_event_scope_, is_mi_root_, suspension_state_, cached_ent_state_, tenant_id_, name_, start_time_, start_user_id_, lock_time_, is_count_enable_, evt_subscr_count_, task_count_, job_count_, timer_job_count_, susp_job_count_, deadletter_job_count_, var_count_, id_link_count_ )?? ??? ?values (@middleProcessId,1,@mainProcessId,null,@mainProcessId,@procDefId,null,@mainProcessId,@middleProcessActKey,0,0,0,0,1,1,null,'',null ,sysdate(),null,null,0,0,0,0,0,0,0,0,0);?? ?-- 當前非標審批環節的處理人數?? ?select count(1) into assigineeCount_ ?from (select substring_index(substring_index(a.approveHandlers,',',d.id+1),',',-1) as assignee from rp_nonstandard_approve a join ( select (id-1) as id from rp_nonstandard_approve c order by id asc limit 21 ) d on d.id<(length(a.approveHandlers)-length(replace(a.approveHandlers,',',''))+1) where a.status = 1 and a.requirementID=businessMainDataId ) g;?? ?select h.approve_handlers into users from rp_nonstandard_approve ?h where h.status = 1 and h.requirementID=businessMainDataId;?? ?-- 中間運行時變量?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfActiveInstances',@middleProcessId,@mainProcessId,null,null,null,assigineeCount_ ?,assigineeCount_ ?,null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfCompletedInstances',@middleProcessId,@mainProcessId,null,null,null,0,0,null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfInstances',@middleProcessId,@mainProcessId,null,null,null,assigineeCount_ ?,assigineeCount_ ?,null) ;?? ?-- 主運行是變量?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'long','requirementId',@mainProcessId,@mainProcessId,null,null,null,businessMainDataId,businessMainDataId,null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'json','users',@mainProcessId,@mainProcessId,null,null,null,null,concat('[',users,']'),null) ;?? ?-- 歷史實例?? ?set @startActId = 'newRequirement';?? ?insert into act_hi_procinst (id_, proc_inst_id_, business_key_, proc_def_id_, start_time_, end_time_, duration_, start_user_id_, start_act_id_, end_act_id_, super_process_instance_id_, delete_reason_,tenant_id_, name_) values(@mainProcessId,@mainProcessId,null,@procDefId,sysdate(),null,null,@startUserId,@startActId,null,null,null,'',@processInstanceName);?? ?open cursor_test2 ;?? ?set @j= 1;?? ?while @j<=assigineeCount_ ?do?? ??? ?fetch cursor_test2 ?into runTaskAssignee ;?? ??? ?-- 根據非標處理人數循環插入執行數據?? ??? ?set @taskProcessId = replace(uuid(),'-','');?? ??? ?insert into act_ru_execution (id_, rev_, proc_inst_id_, business_key_, parent_id_, proc_def_id_, super_exec_, root_proc_inst_id_, act_id_, is_active_, is_concurrent_, is_scope_, is_event_scope_, is_mi_root_, suspension_state_, cached_ent_state_, tenant_id_, name_, start_time_, start_user_id_, lock_time_, is_count_enable_, evt_subscr_count_, task_count_, job_count_, timer_job_count_, susp_job_count_, deadletter_job_count_, var_count_, id_link_count_ )?? ??? ?values (@taskProcessId,1,@mainProcessId,null,@middleProcessId,@procDefId,null,@mainProcessId,@middleProcessActKey,1,0,0,0,0,1,null,'',null ,sysdate(),null,null,0,0,0,0,0,0,0,0,0);?? ?-- 根據非標處理人數循環插入任務數據?? ?-- 任務數據?? ?set @runTaskId = replace(uuid(),'-','');?? ?set @runTaskKey= 'nonStandardApprove';?? ?set @runTaskName= '審批';?? ?set @runTaskAssignee = runTaskAssignee;?? ?insert into act_ru_task (id_,rev_,execution_id_,proc_inst_id_,proc_def_id_,name_,parent_task_id_,description_,task_def_key_,owner_,assignee_,delegation_,priority_,create_time_,due_date_category_,suspension_state_,tenant_id_,form_key_,claim_time_) values (@runTaskId,1,@taskProcessId,@mainProcessId,@procDefId,@runTaskName,NULL,NULL,@runTaskKey,NULL,@runTaskAssignee,NULL,50,sysdate(),null,null,1,'',null,null);?? ?-- 根據非標處理人數循環插入任務??? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'string','user',@taskProcessId,@mainProcessId,null,null,null,null,@runTaskAssignee,null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','loopCounter',@taskProcessId,@mainProcessId,null,null,null,0,'0',null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'string','user',@taskProcessId,@mainProcessId,@runTaskId ,null,null,null,@runTaskAssignee,null) ;?? ??? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','loopCounter',@taskProcessId,@mainProcessId,@runTaskId,null,null,0,'0',null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfActiveInstances',@taskProcessId,@mainProcessId,@runTaskId,null,null,assigineeCount_ ?,assigineeCount_ ?,null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfCompletedInstances',@taskProcessId,@mainProcessId,@runTaskId,null,null,0,'0',null) ;?? ?insert into act_ru_variable (id_, rev_, type_, name_, execution_id_, proc_inst_id_, task_id_, bytearray_id_, double_, long_, text_, text2_) values (replace(uuid(),'-',''),1,'interger','nrOfInstances',@taskProcessId,@mainProcessId,@runTaskId,null,null,assigineeCount_ ?,assigineeCount_ ?,null) ;set @j=@j+1;end while;close cursor_test2 ;set @businessMainDataId = businessMainDataId;set @businessMainDataTable = 't_original_requirement';set @businessCode = businessCode ;insert into rp_pe_business_instance (business_main_data_id,business_main_data_table_name,process_instance_id,version,status,create_by,create_time,update_by,update_by,update_time,is_business_running_process,business_code) values(@businessMainDataId,@businessMainDataTable,@mainProcessId,replace(uuid(),'-',''),1,null,sysdate(),null,sysdate(),1,@businessCode);set @i=@i+1;set result_ =result_ +1;end while;close cursor_test1 ;?select concat('數據處理條數:',result_ ) as resultdata;end;

注意事項:

游標的腳本是在調用open時才會執行,比如我的游標cursor_test2 中有用到businessMainDataId 變量,但是在聲明游標時這個變量是沒有值的,fetch cursor_test1 into startUserId_ ,businessMainDataId ,businessCode 方法執行時才會把這個變量賦值,之后再執行open cursor_test2 時,businessMainDataId 已經有了值,這時就是根據此時的businessMainDataId 查詢的審批數據;

mysql游標與嵌套循環游標嵌套遍歷

user表:

CREATE DEFINER=`root`@`localhost` PROCEDURE `test`()BEGIN DECLARE user1 VARCHAR(100); DECLARE user2 VARCHAR(100); DECLARE done INT DEFAULT 0; DECLARE cursor_user1 CURSOR FOR(SELECT `name` FROM `user`); -- 定于游標1 DECLARE cursor_user2 CURSOR FOR(SELECT `name` FROM `user`); -- 定義游標2 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; -- 結束標識 OPEN cursor_user1; -- 開啟游標1 loop_1: LOOP -- 外層循環 -- -------------------------------------------------------------------------------------# 嘗試從游標1指向的數據集合獲取數據,如果集合已經遍歷完畢,done的值被設置為1。FETCH cursor_user1 INTO user1;IF done = 1 THEN LEAVE loop_1; END IF; -- 外層循環結束條件OPEN cursor_user2; -- 開啟游標2loop_2: LOOP -- 內層循環-- -----------------------------------------------------------------------------# 嘗試從游標2指向的數據集合獲取數據,如果集合已經遍歷完畢,done的值被設置為1。FETCH cursor_user2 INTO user2;IF done = 1 THEN LEAVE loop_2; END IF; -- 內層循環結束條件# do something... -- -----------------------------------------------------------------------------END LOOP loop_2;CLOSE cursor_user2; -- 關閉游標2SET done = 0; -- important -- ------------------------------------------------------------------------------------ END LOOP loop_1; CLOSE cursor_user1; -- 關閉游標1END測試

user表數據:

CREATE DEFINER=`root`@`localhost` PROCEDURE `test`()BEGIN DECLARE result VARCHAR(2000) DEFAULT 'result'; DECLARE user1 VARCHAR(100); DECLARE user2 VARCHAR(100); DECLARE done INT DEFAULT 0; DECLARE cursor_user1 CURSOR FOR(SELECT `name` FROM `user`); -- 定于游標1 DECLARE cursor_user2 CURSOR FOR(SELECT `name` FROM `user`); -- 定義游標2 DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; -- 結束標識 OPEN cursor_user1; -- 開啟游標1 loop_1: LOOP -- 外層循環 -- -------------------------------------------------------------------------------------# 嘗試從游標1指向的數據集合獲取數據,如果集合已經遍歷完畢,done的值被設置為1。FETCH cursor_user1 INTO user1;IF done = 1 THEN LEAVE loop_1; END IF; -- 外層循環結束條件OPEN cursor_user2; -- 開啟游標2loop_2: LOOP -- 內層循環-- -----------------------------------------------------------------------------# 嘗試從游標2指向的數據集合獲取數據,如果集合已經遍歷完畢,done的值被設置為1。FETCH cursor_user2 INTO user2;IF done = 1 THEN LEAVE loop_2; END IF; -- 內層循環結束條件# do something...SET result = CONCAT(result,';',user1,'-',user2); -- -----------------------------------------------------------------------------END LOOP loop_2;CLOSE cursor_user2; -- 關閉游標2SET done = 0; -- important -- ------------------------------------------------------------------------------------ END LOOP loop_1; CLOSE cursor_user1; -- 關閉游標1SELECT result; END

執行結果:

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: MySQL 數據庫
主站蜘蛛池模板: 成人小视频在线看 | 日韩一区二区在线播放 | 国产精品网站在线看 | 日韩精品小视频 | 亚洲系列| 国产激情视频在线 | 久久久久久国产精品 | 亚洲久久 | 91在线成人| 欧美亚洲国产一区 | 操碰97| 亚洲精品日韩激情在线电影 | 欧美日韩专区 | 人人爱超碰 | 午夜精品福利在线观看 | 精品国产三级a在线观看 | 亚洲一区中文 | 国产小视频在线播放 | 久久久久9999国产精品 | 欧美一区二区三区视频 | 国产精品女教师av久久 | 中字一区 | 黄视频在线播放 | 亚洲免费人成在线视频观看 | 欧美精品1区2区 | 亚洲精品www久久久久久广东 | hitomi一区二区三区精品 | 日韩欧美一区二区三区视频 | 精品免费国产 | 午夜影院在线观看 | 99精品久久久 | 欧美日本高清视频 | 99热国产在线观看 | 日韩欧美在线视频 | 日韩成人短视频 | 亚洲国产天堂久久综合 | 青青草免费在线视频 | 亚洲国产婷婷香蕉久久久久久99 | 午夜视频一区二区 | 欧美极品欧美精品欧美视频 | 在线只有精品 | 蜜臀网| 亚洲激情视频在线观看 | 国产看片网站 | 精品国产乱码久久久久久蜜臀 | 午夜影院网站 | 久久精品首页 | 国产精品一区二区三区在线免费观看 | 免费欧美一级 | 成人亚洲天堂 | 亚洲欧洲日本国产 | 国产美女精品视频免费观看 | 成人不卡 | 国产999精品久久久久 | 中文字幕亚洲一区二区va在线 | 一区二区三区国产精品 | 狠狠躁夜夜躁人人爽天天天天97 | 毛片网站大全 | 欧美8一10sex性hd| 欧美日韩一区二区视频在线观看 | 欧美日韩在线观看中文字幕 | 999国内精品永久免费视频 | 中文av在线播放 | 精品1区| 麻豆成人在线 | 精品国产乱码久久久久久影片 | 国产乱码一区二区三区在线观看 | 国产一区二区三区四区五区加勒比 | 国产女爽爽视频精品免费 | 精品久久久久久久久久久久久久 | 91麻豆精品国产91久久久久久久久 | 性色av一区二区三区 | 天天干天天插天天 | 99久久婷婷国产精品综合 | 久久999| 一级毛片色一级 | 欧美日本一区 | 大桥未久亚洲精品久久久强制中出 | 成人在线观看免费 | 久久久久久精 | 久草在线高清 | 中文字幕第一页在线 | 国产免费一区二区三区 | 日本日韩中文字幕 | 免费一区 | 成人在线视频一区 | 午夜国产视频 | 91在线观看视频 | 免费h在线观看 | 国产在线专区 | 国产成人福利在线 | 久久久久国产视频 | 国产日韩一区二区 | av免费观看网站 | 国产成人久久精品麻豆二区 | 午夜伦理影院 | 午夜免费高清视频 | 综合99 | 久久久精品日韩 | 国产精品二区三区 | 国产精品国产三级国产aⅴ原创 | 国产精品欧美一区二区三区 | 91在线网址| 亚洲精美视频 | 九九爱爱视频 | 国产在线观看一区 | 成人午夜在线 | 亚洲一区二区三区四区五区中文 | 成人五月网 | 国产毛片在线看 | 国产日韩一区二区三区 | 久久高清亚洲 | 国产亚洲成av人片在线观看桃 | 蜜桃视频一区二区三区 | 另类免费视频 | 三级成人在线 | 91九色视频pron | 亚洲精品一区二区在线观看 | 国产成人精 | 国产视频2021 | 精品美女在线 | 国内精品视频一区 | 久久精品小视频 | 凹凸日日摸日日碰夜夜 | 欧美一区免费 | 久久99成人| 国产日韩在线播放 | 日本亚洲欧美 | 午夜在线电影 | 成人欧美一区二区三区在线播放 | 91亚洲精品乱码久久久久久蜜桃 | 欧美一区二区三区四区不卡 | 国产精品成人3p一区二区三区 | 免费黄色电影在线观看 | 最新国产视频 | 免费看片91| 国产精品日本欧美一区二区三区 | 久久久久久久久99精品 | 91丁香婷婷综合久久欧美 | 国产成人99久久亚洲综合精品 | 国产成人av电影 | 免费毛片网站 | 久久精品亚洲一区二区 | 久久久久国产精品 | 国产精品久久久久久久久久久久冷 | 91极品在线| 福利视频一区二区三区 | 亚洲成人久久久 | 一区二区三区欧美在线 | 欧美中文字幕在线 | 国产日韩欧美视频 | 国产精品精品久久久 | 国产高清视频 | 精品国产乱码久久久久夜 | 中文在线视频 | 特黄级国产片 | 国产日韩欧美亚洲 | 国产一区二区视频在线观看 | 在线免费看a | 日韩在线视频中文字幕 | 免费大片在线观看网站 | 国产精品久久久久久吹潮 | a级毛片免费高清视频 | 永久免费精品视频 | 欧美最猛性xxxxx亚洲精品 | 男人天堂999 | 久久久久久毛片免费播放 | 国产免费av网站 | 欧美国产一区二区 | 欧美成人性生活 | 免费成人在线网站 | 成人亚洲在线观看 | 美日韩精品 | 黄色片视频在线观看 | 小情侣高清国产在线播放 | 欧美日韩国产综合视频 | 97久久精品人人做人人爽50路 | 9999久久久久 | 永久91嫩草亚洲精品人人 | 久久国产精品一区 | 国产成人99久久亚洲综合精品 | 一级毛片在线免费看 | 成人免费xxxxx在线观看 | h在线视频 | 黄色网址大全在线观看 | 欧洲一级视频 | 欧美日韩在线免费观看 | 欧美激情一区二区三区蜜桃视频 | 国产男人的天堂 | 操皮视频 | 欧美日韩h | 啊啊啊网站 | 日韩成年视频 | 91精品国产综合久久久久久 | www狠狠干 | 国产高清久久久 | 成人免费网站www网站高清 | 日韩不卡一区二区 | 日韩欧美~中文字幕 | 五月婷综合 | 视频一区二区国产 | 福利在线播放 | 欧美精品1区2区 | 性培育学校羞耻椅子调教h 欧美精品网站 | 中文字幕一区二区三区四区 | 久久久久国产视频 | 久久精品亚洲精品国产欧美 | 精品视频久久 | 999视频在线 | 久久久精品网 | 偷拍自拍网站 | 日本a在线 | 国产96精品久久久 | 国产一区二区精品 | 91福利视频导航 | 欧美亚洲另类在线 | www.狠狠干 | 日韩精品在线一区 | 国产在线2 | 国产欧美日韩综合精品 | 久久久一区二区三区 | 午夜影视| 国产日韩精品视频 | 精品亚洲国产成av人片传媒 | 欧美一级精品片在线看 | www.久久99| 一区二区在线播放视频 | 欧美日韩国产综合视频 | 精产国产伦理一二三区 | 中国免费看的片 | 精品成人一区 | 99精品欧美一区二区蜜桃免费 | 午夜私人影院在线观看 | 国产成人av在线 | 九九在线国产视频 | 精品久久久久久亚洲精品 | 欧美一级淫片免费看 | 我和我的祖国电影在线观看免费版高清 | 亚洲一区在线视频 | 欧美视频一二 | 一级片免费视频 | 亚洲免费精品 | 欧美精品免费在线 | 久久久久久久国产精品 | 成人免费大片黄在线播放 | 久久男人 | 免费亚洲婷婷 | 99热日本| 国产日韩在线播放 | 国产视频久久精品 | 欧美一区二区三区男人的天堂 | 国产精品99久久久久久久久久久久 | 成人精品久久久 | 91视频在线| 中国大陆高清aⅴ毛片 | 日韩成人在线影院 | 日本在线观看视频一区 | 黄色在线免费观看 | 国产片在线观看 | 色噜噜狠狠狠综合曰曰曰88av | 农村末发育av片四区五区 | 亚洲成人在线视频播放 | 国产精品 日韩 | 久草精品在线 | 伊人干综合 | 可以看av的网站 | 午夜私人视频 | 亚洲一本| 欧美一区二区激情三区 | 日韩视频一区二区 | 久久久精品综合 | 自拍偷拍欧美 | 精品国产一区二区在线 | 欧美一区二区免费 | 精品国产一区二区三区在线观看 | 不卡一区二区三区四区 | 国产伊人av | 亚洲成a人 | 国产成人精品久久 | 中文字幕一区二区三区四区 | 懂色av一区二区三区在线播放 | 一级片在线观看 | 日韩高清一区二区 | av免费在线观看网站 | 免费色在线 | 91视频网址 | 欧美1级| www久久久久久久 | 国产精品久久久久无码av | 91成人免费视频 | 中文字幕亚洲欧美日韩在线不卡 | 欧美成人专区 | 午夜www | 亚洲精品无 | 国产精品99久久久久久久vr | 中文欧美日韩 | 性色在线 | 中文字幕亚洲在线 | 日韩色综合 | 特黄一级 | 国色天香成人网 | 久久夜精| 国产精品国产a级 | 美女主播精品视频一二三四 | 成人欧美一区二区三区 | 黄网在线观看 | 一级a性色生活片毛片 | 久久久精彩视频 | 免费看黄视频网站 | 国产999精品久久久影片官网 | 狠狠久久婷婷 | www久久久 | 亚洲精品一 | 久久免费视频网 | 综合久久综合 | 精品久久久久久国产 | 一本一道久久a久久精品逆3p | 伊人伊人网 | 国产精品视频免费看 | 在线日韩 | 91精品国产综合久久久久久软件 | 亚洲91精品 | 婷婷亚洲综合 | 精品一区二区在线观看 | 国产精品久久久久久久久岛 | 美女在线视频一区二区 | 91精品中文字幕一区二区三区 | 欧美黑人做爰xxxⅹ 国产精品一区二区视频 | 97成人在线 | 日日爽 | 91社影院在线观看 | 亚洲成人一区二区 | 国产精品久久久久久久美男 | 黄色网址av | 国产在线观看一区 | 久久日韩 | 久久国产精品一区 | 亚洲国产婷婷香蕉久久久久久99 | 在线亚洲免费 | 久久综合九九 | 久久精品中文 | 婷婷丁香激情 | 久久久999精品视频 五月天婷婷在线视频 | 高清免费av | 亚洲综合色网 | 日韩一区欧美 | 欧美午夜精品久久久 | 国产中文字幕一区 | 亚洲精品网址 | 亚洲成人av| 黄免费视频 | 国产伦精品久久久一区二区三区 | 亚洲国产精品一区二区三区 | 欧美日韩在线视频一区 | 久久亚洲精品国产一区 | 国产成人涩涩涩视频在线观看 | 免费看片www| 欧美日韩一区二区视频在线观看 | 亚洲 欧美 激情 另类 校园 | 久久午夜视频 | 免费看91| 日本少妇bbbb爽爽bbb美 | 国产ts余喵喵和直男多体位 | 国产精品日本一区二区不卡视频 | 日日久 | 精品视频免费观看 | 精品精品 | 日韩高清一区 | a∨在线观看 | 一级片日韩| 国产高清一级 | 中文字幕一区二区在线观看 | 欧美二三区| 精品国产污网站污在线观看15 | 色综合久久久久综合99 | 啪啪的网站 | 国产超碰在线观看 | 国产精品毛片无码 | 国产精品一区二区久久 | 精品成人免费视频 | 国产91久久精品一区二区 | 蜜桃视频一区 | 色花av | 国产精品久久久久久一区二区三区 | 亚洲97色| 久久婷婷香蕉 | 99精品网| 日本久久网 | 欧美啪 | 国产精品久久久 | 一区二区三区四区国产 | 亚洲欧美日韩电影 | 一级片在线观看 | 午夜精品一区二区三区在线观看 | 一区二区三区免费 | 亚洲一区二区三区四区五区中文 | www.色94色.com| 99精品国产高清一区二区麻豆 | 久久久久久久91 | 成人在线片| 国产精品久久久久久亚洲调教 | 国产精品一区一区三区 | 韩日精品在线观看 | 国产美女黄色片 | 国产农村妇女精品久久 | 成人精品在线观看 | 午夜精品亚洲日日做天天做 | 欧美日韩免费在线 | 成人永久免费视频 | 日韩第一区 | 黄色av观看| 久久精品视频网 | 亚洲第一福利视频 | 黄色一级免费看 | 精品视频99 | 国产精品久久久久久久久久免费看 | 亚洲一区二区在线播放 | 日韩视频一二 | 精品护士一区二区三区 | 91成人免费看片 | 国产毛片毛片 | 天天操狠狠操 | 亚洲欧美日韩电影 | 在线观看三级av | 欧美理论片在线 | 狠狠操网站 | 亚洲国产精品一区二区三区 | 日韩精品视频免费看 | 欧美日韩一区二区三区在线电影 | 国产高清免费 | 91久久精品一区二区三区 | 可以免费在线观看av的网站 | 国产精品久久久久无码av | 欧美视频网站 | 成人在线精品 | 日韩国产一区二区三区 | 国产精品久久久久久久久免费桃花 | 欧美一级片在线 | 婷五月综合 | 久久精品欧美一区二区三区不卡 | 日本综合久久 | 99热精品在线 | 日韩精品一区二区三区中文在线 | 91精品久久久久 | 婷婷91 | 91精品国产美女在线观看 | 欧美在线a| 一区二区中文 | 国产韩国精品一区二区三区 | 成人欧美 | 男人的天堂亚洲 | h视频在线免费观看 | 亚洲综合在线网 | 亚洲成人精品在线 | 91精品国产综合久久久久久蜜月 | 亚洲天天操 | 中文字幕国产一区 | 女同久久 | 色婷婷综合久久久中字幕精品久久 | 欧美黑人xx | 北条麻妃一区二区三区在线 | 在线观看日韩精品 | 亚洲精品在线播放 | 色吧久久 | 久久精选视频 | 在线观看视频一区二区 | 精品久久99 | 交视频在线观看国产 | 日本a在线 | 99精品视频在线观看 | 亚洲国产一区视频 | 狠狠影院 | vagaa欧洲色爽免影院 | 久草.com| 日韩精品在线免费观看视频 | 最新国产中文字幕 | 成人一二三区 | 久久精品1区2区 | 国产女无套免费网站 | www.99精品 | 在线观看日韩 | 国产综合在线视频 | 亚洲一区二区三区免费在线 | 国产小视频在线看 | 色必久久| 91欧美激情一区二区三区成人 | 久久99精品久久久久久久青青日本 | 成人精品一区二区 | 北条麻妃一区二区三区在线 | 国产伦精品一区二区三区四区视频 | 鲁视频| 国产亚洲精品一区二区 | 欧美一区二区免费 | 国产不卡免费 | 伊人伊人伊人 | 成人h视频 | 久久91精品国产 | 午夜精品久久久久久久 | 一区二区视频网站 | 国产福利在线视频 | 中文字幕av网 | 国产精品一区一区三区 | 亚洲一区视频在线 | 欧美精品成人一区二区三区四区 | 午夜寂寞影视在线观看 | 日本中文在线 | 久热99 | 成人免费视频网站在线观看 | 欧美三级视频 | 国产一区二区视频精品 | 国产成人午夜视频 | 亚洲精片 | 亚洲精品粉嫩美女一区 | 久久婷婷麻豆国产91天堂 | 亚洲免费视频在线观看 | 欧美hdfree性xxxx | 精品毛片 | 亚洲精品高清视频 | 国产精品久久久久久中文字 | 国产免费一区二区 | 亚洲国产精品一区二区三区 | 黄色毛片在线看 | 欧美成人精品一区二区男人看 | 99re在线视频 | 亚洲福利影院 | 波多野结衣一区二 | 精品国产91久久久久久久 | av在线一区二区三区 | 欧美成人在线网站 | 国产午夜久久 | 日日干,天天干 | 欧美精品一区在线 | 在线国产视频 | 亚洲精品乱码久久久久久花季 | 国产在线视频一区二区 | 欧美日韩一区二区三区在线观看 | 日日操视频 | 亚洲一区中文字幕在线观看 | 欧美专区在线观看 | 国产成人片 | 中文字幕在线观看亚洲 | 久久久久久这里只有精品 | 欧美日韩一区二区三区在线观看 | 日本高清视频在线播放 | 成人一级黄色大片 | aⅴ色国产 欧美 | 欧美 日韩 亚洲 一区 | 亚洲aⅴ网站 | 国产福利精品一区 | 色吊丝2288sds中文字幕 | 91porn在线| 亚洲精品久久久久久一区二区 | 欧美日韩三级 | 欧美在线观看一区二区 | 欧美大成色www永久网站婷 | 激情欧美日韩一区二区 | 91精品一区二区三区久久久久久 | 国产精品久久国产精品 | 中文字幕视频在线观看 | 91九色最新 | 国产精品日韩欧美一区二区 | 中国大陆高清aⅴ毛片 | 中文字幕八区 | 激情在线观看视频 | 影音先锋国产 | 天天草综合 | 国产毛片在线看 | a成人在线 | 夜夜骑天天射 | 操视频网站 | 在线视频一区二区三区 | 欧美激情欧美激情在线五月 | 香蕉视频在线看 | 欧美一级小视频 | 久草精品在线观看 | 国产探花在线看 | 日韩精品网站在线观看 | 欧美日韩精品一区二区 | 一二三区不卡视频 | 久久久久久久 | 少妇精品视频在线观看 | 五月天婷婷国产精品 | 国产成人一区二区三区 | 嫩草视频在线播放 | 日韩欧美国产一区二区 | 久久久久久久久久国产 | 亚洲人网站 | 久久国产精彩视频 | 国产精品一区二区三区av | 久久九九精品视频 | 欧美日韩中文在线 | 亚洲欧美在线视频 | 色婷婷国产精品免费网站 | 午夜影院在线观看 | 国产一级淫片a级aaa | 啪啪毛片 | 国产精品欧美久久久久一区二区 | 最新午夜综合福利视频 | 亚洲一区二区三区在线播放 | 久久久久无码国产精品一区 | 国产精品久久久久久久免费大片 | 91色站| 91亚洲免费 | 久久久久久国产精品 | 精品国产91亚洲一区二区三区www | 久久久久久久99精品免费观看 | 国产成人免费视频网站视频社区 | 婷婷综合五月 | 美女视频久久 | 天天看天天摸天天操 | 黄色一级在线播放 | 日本久久网 | 亚洲乱码一区二区三区在线观看 | 午夜视频网址 | 断背山在线|