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

Oracle 分區(qū)表之在線重定義

數(shù)據(jù)庫(kù) Oracle
在線重定義表是從oracle9i開始提供的一個(gè)功能,能在線完成對(duì)一個(gè)表結(jié)構(gòu)或存儲(chǔ)的重定義,并且不影響當(dāng)前應(yīng)用的使用,是oracle高可用性中的一個(gè)很有用的特性。

一、介紹

「DBMS_REDEFINITION(在線重定義):」

  • 「支持的數(shù)據(jù)庫(kù)版本」:Oracle Database - Enterprise Edition - Version 9.2.0.4 and later
  • 在線重定義是通過(guò) 「物化視圖」 實(shí)現(xiàn)的。

「使用在線重定義的一些限制條件」:

  • 必須有足夠的表空間來(lái)容納表的兩倍數(shù)據(jù)量。
  • 主鍵列不能被修改。
  • 表必須有主鍵。
  • 必須在同一個(gè)用戶下進(jìn)行在線重定義。
  • SYS和SYSTEM用戶下的表無(wú)法進(jìn)行在線重定義。
  • 在線重定義無(wú)法采用nologging。
  • 如果中間表有新增列,則不能有NOT NULL約束

「DBMS_REDEFINITION包:」

  • ABSORT_REDEF_TABLE:清理重定義的錯(cuò)誤和中止重定義;
  • CAN_REDEF_TABLE:檢查表是否可以進(jìn)行重定義,存儲(chǔ)過(guò)程執(zhí)行成功代表可以進(jìn)行重定義;
  • COPY_TABLE_DEPENDENTS:同步索引和依賴的對(duì)象(包括索引、約束、觸發(fā)器、權(quán)限等);
  • FINISH_REDEF_TABLE:完成在線重定義;
  • REGISTER_DEPENDENTS_OBJECTS:注冊(cè)依賴的對(duì)象,如索引、約束、觸發(fā)器等;
  • START_REDEF_TABLE:開始在線重定義;
  • SYNC_INTERIM_TABLE:增量同步數(shù)據(jù);
  • UNREGISTER_DEPENDENT_OBJECT:不注冊(cè)依賴的對(duì)象,如索引、約束、觸發(fā)器等;

二、實(shí)戰(zhàn)

1、構(gòu)建測(cè)試數(shù)據(jù)創(chuàng)建測(cè)試表空間和用戶:

  1. sqlplus / as sysdba 
  2. create tablespace PAR; 
  3. create user par identified by par; 
  4. grant dba to par; 

創(chuàng)建測(cè)試表:

  1. sqlplus par/par 
  2. create table lucifer( 
  3. id number(8) PRIMARY KEY
  4. name varchar2(20) not null
  5. par_date date
  6. tablespace PAR; 
  7. comment on table lucifer is 'lucifer表'
  8. comment on column lucifer.name is '姓名'
  9. comment on column lucifer.par_date is '分區(qū)日期'
  10. create index id_name on lucifer(name) tablespace par; 

 

插入測(cè)試數(shù)據(jù):

  1. sqlplus par/par 
  2. begin 
  3.   for i in 0 .. 24 loop 
  4.     insert into lucifer values 
  5.       (i, 
  6.        'lcuifer_' || i, 
  7.        add_months(to_date('2021-1-1''yyyy-mm-dd'), i)); 
  8.   end loop; 
  9.   commit
  10. end

可以看到,測(cè)試數(shù)據(jù)已經(jīng)構(gòu)建完成,接下來(lái)開始實(shí)戰(zhàn)操作。

2、查看是否能夠重定義

需提前確認(rèn)表是否有主鍵,表空間是否足夠:

  1. sqlplus / as sysdba 
  2. ##查看主鍵 
  3. select cu.* from user_cons_columns cu, user_constraints au where cu.constraint_name = au.constraint_name and au.constraint_type = 'P' and au.table_name = 'LUCIFER'

確認(rèn)是否可以重定義,沒(méi)有主鍵用 rowid:

  1. sqlplus / as sysdba 
  2. exec dbms_redefinition.can_redef_table('PAR''LUCIFER'); 

執(zhí)行沒(méi)有報(bào)錯(cuò)代表可以進(jìn)行表的在線重定義。

3、創(chuàng)建中間表(分區(qū)表結(jié)構(gòu))

通過(guò)PL/SQL包一鍵生成分區(qū)表結(jié)構(gòu):

  1. sqlplus par/par 
  2. BEGIN 
  3.   ctas_par(p_tab        => 'lucifer'
  4.            p_part_colum => 'par_date'
  5.            p_part_nums  => 24, 
  6.            p_tablespace => 'par'); 
  7. END

創(chuàng)建中間分區(qū)表 lucifer_par:

  1. create table lucifer_par 
  2.   id       NUMBER(8), 
  3.   name     VARCHAR2(20), 
  4.   par_date DATE 
  5. partition BY RANGE(par_date)( 
  6. partition lucifer_P202101 values less than (TO_DATE(' 2021-02-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  7. partition lucifer_P202102 values less than (TO_DATE(' 2021-03-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  8. partition lucifer_P202103 values less than (TO_DATE(' 2021-04-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  9. partition lucifer_P202104 values less than (TO_DATE(' 2021-05-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  10. partition lucifer_P202105 values less than (TO_DATE(' 2021-06-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  11. partition lucifer_P202106 values less than (TO_DATE(' 2021-07-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  12. partition lucifer_P202107 values less than (TO_DATE(' 2021-08-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  13. partition lucifer_P202108 values less than (TO_DATE(' 2021-09-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  14. partition lucifer_P202109 values less than (TO_DATE(' 2021-10-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  15. partition lucifer_P202110 values less than (TO_DATE(' 2021-11-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  16. partition lucifer_P202111 values less than (TO_DATE(' 2021-12-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  17. partition lucifer_P202112 values less than (TO_DATE(' 2022-01-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  18. partition lucifer_P202201 values less than (TO_DATE(' 2022-02-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  19. partition lucifer_P202202 values less than (TO_DATE(' 2022-03-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  20. partition lucifer_P202203 values less than (TO_DATE(' 2022-04-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  21. partition lucifer_P202204 values less than (TO_DATE(' 2022-05-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  22. partition lucifer_P202205 values less than (TO_DATE(' 2022-06-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  23. partition lucifer_P202206 values less than (TO_DATE(' 2022-07-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  24. partition lucifer_P202207 values less than (TO_DATE(' 2022-08-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  25. partition lucifer_P202208 values less than (TO_DATE(' 2022-09-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  26. partition lucifer_P202209 values less than (TO_DATE(' 2022-10-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  27. partition lucifer_P202210 values less than (TO_DATE(' 2022-11-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  28. partition lucifer_P202211 values less than (TO_DATE(' 2022-12-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  29. partition lucifer_P202212 values less than (TO_DATE(' 2023-01-01 00:00:00''SYYYY-MM-DD HH24:MI:SS''NLS_CALENDAR=GREGORIAN')) tablespace par, 
  30. partition lucifer_MAX values less than (maxvalue) tablespace par) 
  31.              enable row movement 
  32.              tablespace par; 

如上,唯一索引和約束不加,會(huì)自動(dòng)復(fù)制,分區(qū)表結(jié)構(gòu)的中間表已經(jīng)生成。

4、檢查中間表是否開啟行遷移

  1. select row_movement from dba_tables where table_name='LUCIFER' and owner='PAR'
  2. select row_movement from dba_tables where table_name='LUCIFER_PAR' and owner='PAR'

5、收集表統(tǒng)計(jì)信息

為了確保數(shù)據(jù)準(zhǔn)確,開始前進(jìn)行統(tǒng)計(jì)信息收集:

  1. sqlplus / as sysdba 
  2. exec dbms_stats.gather_table_stats(ownname => 'PAR',tabname => 'LUCIFER',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE,degree => '8') ; 
  3. exec dbms_stats.gather_table_stats(ownname => 'PAR',tabname => 'LUCIFER_PAR',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE,degree => '8') ; 

6、開始在線重定義

  1. sqlplus / as sysdba 
  2. EXEC DBMS_REDEFINITION.START_REDEF_TABLE('PAR','LUCIFER','LUCIFER_PAR'); 

7、復(fù)制表屬性,排除索引

選擇自動(dòng)復(fù)制表屬性,手動(dòng)創(chuàng)建本地索引(local):

  • 優(yōu)點(diǎn):只需要關(guān)注索引是否遺漏,無(wú)需關(guān)注觸發(fā)器,權(quán)限,約束等依賴。
  • 缺點(diǎn):需要手動(dòng)創(chuàng)建索引,并且結(jié)束后手動(dòng)rename索引。
  1. sqlplus par/par 
  2. SET SERVEROUTPUT ON 
  3. DECLARE 
  4.   l_errors  NUMBER; 
  5. BEGIN 
  6.   DBMS_REDEFINITION.copy_table_dependents( 
  7.     uname            => USER
  8.     orig_table       => 'LUCIFER'
  9.     int_table        => 'LUCIFER_PAR'
  10.     copy_indexes     => 0, 
  11.     copy_triggers    => TRUE
  12.     copy_constraints => TRUE
  13.     copy_privileges  => TRUE
  14.     ignore_errors    => FALSE
  15.     num_errors       => l_errors, 
  16.     copy_statistics  => FALSE
  17.     copy_mvlog       => FALSE); 
  18.      
  19.   DBMS_OUTPUT.put_line('Errors=' || l_errors); 
  20. END

執(zhí)行過(guò)程沒(méi)有任何報(bào)錯(cuò),代表正常。

8、中間表創(chuàng)建本地索引

中間表LUCIFER_PAR創(chuàng)建索引:

  1. create index ID_NAME_PAR on LUCIFER_PAR(NAME) tablespace PAR local parallel 8; 

注意:索引名稱需要與原索引名稱不一致。

9、取消索引并行度

如果創(chuàng)建索引時(shí),開啟并行創(chuàng)建,則需要取消索引并行度:

  1. sqlplus / as sysdba 
  2. select 'alter index '||owner||'.'||index_name||' noparallel;' 
  3. from dba_indexes  
  4. where table_name = 'LUCIFER_PAR' and owner= 'PAR'

10、同步數(shù)據(jù)(可以減少結(jié)束重定義過(guò)程的鎖表時(shí)間)

  1. sqlplus / as sysdba 
  2. BEGIN 
  3. dbms_redefinition.sync_interim_table( 
  4. uname => 'PAR'
  5. orig_table => 'LUCIFER'
  6. int_table => 'LUCIFER_PAR'); 
  7. END

注意: 這一步操作是為了在結(jié)束重定義的時(shí)候,減少鎖表的時(shí)間。

11、收集中間表統(tǒng)計(jì)信息

為了下面同步數(shù)據(jù)做準(zhǔn)備,收集中間表統(tǒng)計(jì)信息:

  1. sqlplus / as sysdba 
  2. exec dbms_stats.gather_table_stats(ownname => 'PAR',tabname => 'LUCIFER_PAR',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE,degree => '8') ; 

12、結(jié)束重定義(結(jié)束重定義需要鎖表,具體時(shí)間根據(jù)表的大小決定)

  1. sqlplus / as sysdba 
  2. BEGIN 
  3. dbms_redefinition.finish_redef_table( 
  4. uname => 'PAR'
  5. orig_table => 'LUCIFER'
  6. int_table => 'LUCIFER_PAR'); 
  7. END

13、查看分區(qū)表是否已轉(zhuǎn)換

  1. sqlplus par/par 
  2. select owner,table_name,partitioned from user_tables where table_name in ('LUCIFER','LUCIFER_PAR'); 

如上,LUCIFER表已經(jīng)在線重定義為分區(qū)表結(jié)構(gòu)。

14、手動(dòng)修改重命名索引

此時(shí),原表名的表已經(jīng)轉(zhuǎn)換為中間表,需要先將原表的索引,rename到其他名字,本次是BAK,需要注意索引名稱長(zhǎng)度不能過(guò)長(zhǎng)

  1. sqlplus / as sysdba 
  2. ALTER index PAR.ID_NAME RENAME TO ID_NAME_BAK; 

rename新分區(qū)表索引,由于新分區(qū)表的索引名稱還是中間表的索引名稱,所以需要手動(dòng)rename:

  1. sqlplus / as sysdba 
  2. ALTER index PAR.ID_NAME_PAR RENAME TO ID_NAME; 

15、查看是否存在無(wú)效索引

  1. sqlplus / as sysdba 
  2. SELECT owner index_owner, index_name, index_type,'N/A' partition_name,status,table_name,tablespace_name, 
  3.   'alter index '||owner||'.'||index_name||' rebuild;' rebuild_index 
  4.   FROM dba_indexes 
  5. WHERE status = 'UNUSABLE' 
  6. UNION ALL 
  7. SELECT a.index_owner,a.index_name,b.index_type,a.partition_name,a.status,b.table_name,a.tablespace_name, 
  8. 'alter index '||a.index_owner||'.'||a.index_name||' rebuild partition '||a.partition_name||' ;' rebuild_index 
  9.   FROM dba_ind_partitions a, dba_indexes b 
  10. WHERE a.index_name = b.index_name 
  11.    AND a.index_owner = b.owner 
  12.    AND a.status = 'UNUSABLE' 
  13. UNION ALL 
  14. SELECT owner index_owner,a.index_name,b.index_type,'N/A' partition_name,a.status,b.table_name,NULL
  15. 'alter index '||a.index_owner||'.'||a.index_name||' rebuild subpartition '||a.subpartition_name||';' rebuild_index 
  16.   FROM dba_ind_subpartitions a, dba_indexes b 
  17. WHERE a.index_name = b.index_name 
  18.    AND a.index_owner = b.owner 
  19.    AND a.status = 'UNUSABLE'

16、檢查切換后是否開啟row_movement

  1. sqlplus / as sysdba 
  2. select owner,table_name,row_movement from dba_tables where table_name in ('LUCIFER','LUCIFER_PAR'and owner='PAR'

17、檢查無(wú)效對(duì)象

  1. ##無(wú)效對(duì)象編譯 
  2. sqlplus / as sysdba  
  3. @?/rdbms/admin/utlrp.sql 
  4.  
  5. select  'alter  '||object_type||'   '||owner||'.'||object_name||'   compile;' 
  6. from  dba_objects t 
  7. where t.status = 'INVALID' order by 1; 

 

18、收集統(tǒng)計(jì)信息

  1. sqlplus / as sysdba 
  2. exec dbms_stats.gather_table_stats(ownname => 'PAR',tabname => 'LUCIFER',estimate_percent => 10,method_opt=> 'for all indexed columns',cascade=>TRUE,degree => '8') ; 

19、插入測(cè)試數(shù)據(jù)

  1. sqlplus par/par 
  2. begin 
  3.   for i in 100 .. 124 loop 
  4.     insert into lucifer values 
  5.       (i, 
  6.        'lcuifer_' || i, 
  7.        add_months(to_date('2021-5-1''yyyy-mm-dd'), i)); 
  8.   end loop; 
  9.   commit
  10. end

20、查詢分區(qū)表數(shù)據(jù)分布

  1. sqlplus par/par 
  2. SELECT COUNT(*) FROM  LUCIFER; 
  3. SELECT * FROM  LUCIFER PARTITION(LUCIFER_P202101); 
  4. SELECT * FROM  LUCIFER PARTITION(LUCIFER_P202201); 
  5. SELECT * FROM  LUCIFER PARTITION(LUCIFER_MAX); 

可以發(fā)現(xiàn),數(shù)據(jù)已經(jīng)根據(jù)日期均勻分布在不同的子分區(qū)中。

至此,在線重定義已經(jīng)完成,分區(qū)表已成功轉(zhuǎn)換。

「參考MOS文檔:」

  • How To Partition Existing Table Using DBMS_REDEFINITION (Doc ID 472449.1)

 

責(zé)任編輯:姜華 來(lái)源: Lucifer三思而后行
相關(guān)推薦

2009-06-24 10:26:41

Oracle約束分區(qū)表

2021-01-20 08:07:52

oracle分區(qū)單表

2017-07-04 11:02:40

Oracle新列分區(qū)

2023-10-11 13:42:21

2010-04-19 14:01:22

Oracle查看分區(qū)表

2011-04-11 11:32:29

Oracle分區(qū)表磁盤IO沖突

2023-01-30 09:13:17

Oracle分區(qū)表技術(shù)

2017-08-30 16:59:54

PostgreSQL分區(qū)表

2011-08-23 10:37:15

Oracle分區(qū)表本地索引

2010-10-11 10:16:17

Mysql分區(qū)表

2010-11-22 15:06:46

MySQL分區(qū)表

2011-03-22 14:49:35

Oracle數(shù)據(jù)庫(kù)重定義表

2011-03-22 14:57:52

Oracle數(shù)據(jù)庫(kù)普通表分區(qū)表

2021-09-07 17:54:04

OpenGauss分區(qū)表索引

2010-10-11 09:50:32

Mysql分區(qū)表

2021-04-19 08:16:38

Hive數(shù)據(jù)類型大數(shù)據(jù)技術(shù)

2010-04-16 13:41:14

Oracle表分區(qū)

2009-08-17 08:35:22

Linux掛載分區(qū)表fstab

2011-08-11 15:34:26

Oracle數(shù)據(jù)庫(kù)新增字段在線重定義

2010-04-19 14:23:34

Oracle增加表分區(qū)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美日韩电影在线播放| 欧美视频在线一区二区三区| 在线视频一区二区| 91激情视频在线| 中文字幕在线播放| 麻豆91精品视频| 日韩成人影院| 国产成人免费视频一区| 欧美激情高清视频| 天天插天天射天天干| 裤袜国产欧美精品一区| 亚洲欧美在线观看| 日韩欧美国产一区二区| 国产亚洲欧美另类一区二区三区 | 69av视频在线观看| 亚洲精品97| 日韩精品中文字幕视频在线| 蜜臀一区二区三区精品免费视频 | 国产精品黄色av| www青青草原| 欧美精品一区二区三区中文字幕| 欧美一区二区三区色| 久色视频在线播放| 操你啦视频在线| 国产亚洲综合av| 国产区日韩欧美| 国产三级小视频| 人人超碰91尤物精品国产| 欧美激情一二三| 最新黄色av网址| 精品一区三区| 日韩成人av一区| 亚洲AV成人精品| 亚洲精品大全| 欧美无乱码久久久免费午夜一区| 热99这里只有精品| 色噜噜狠狠狠综合欧洲色8| 欧美国产日韩亚洲一区| 久久精品一区二区三区不卡免费视频| 国产高潮在线观看| 久久精品国产精品亚洲综合| 国产成人一区二区在线| 色婷婷av国产精品| 亚洲二区精品| 国外成人在线播放| 国产在线一区视频| 欧美在线三区| 欧美第一淫aaasss性| 天海翼在线视频| 97视频热人人精品免费| 在线视频中文亚洲| 欧美亚洲色综久久精品国产| 精品久久91| 亚洲最新av在线| 国产伦精品一区二区三区视频女| 欧美猛男男男激情videos| 亚洲精品一区在线观看香蕉| 欧美精品欧美极品欧美激情| 日韩人体视频| 亚洲美腿欧美激情另类| 国产中年熟女高潮大集合| 性人久久久久| 伊人av综合网| 一级特黄曰皮片视频| 日韩成人影院| 大胆人体色综合| 少妇久久久久久被弄高潮| 欧美区国产区| 国外成人免费在线播放| 国产又黄又粗又爽| 日本成人中文字幕在线视频| 国产欧美亚洲精品| 国产免费福利视频| 成人精品国产一区二区4080| 久久国产精品精品国产色婷婷| 亚洲三级黄色片| 91偷拍与自偷拍精品| 日本在线观看一区二区| 免费人成在线观看播放视频| 亚洲免费伊人电影| 91.com在线| 最新欧美色图| 欧美精品一卡二卡| 91精品人妻一区二区三区四区| 国产精品美女在线观看直播| 国产视频久久久久| 毛片视频免费播放| 国产在线欧美| 国产精品成人v| 99热这里只有精品在线| 99视频在线观看一区三区| 日韩福利视频| 免费网站在线观看人| 色婷婷激情久久| 欧美激情第一区| 久久动漫网址| 日韩在线小视频| 日韩成人高清视频| 蜜桃视频在线观看一区| 国产精品xxxx| 日本精品在线| 欧美日韩亚洲高清| 玖玖爱视频在线| 天堂综合网久久| 久久香蕉国产线看观看网| a v视频在线观看| 精品一区二区三区视频在线观看 | 亚洲国产一区二区三区| 男人女人黄一级| 澳门成人av| 俺去了亚洲欧美日韩| 日日夜夜综合网| 国产精品一区免费在线观看| 欧美连裤袜在线视频| 欧美性video| 欧美视频一区二区三区| 中国极品少妇xxxx| 国产精品99视频| 日本精品视频在线观看| 精品区在线观看| 国产精品久久久久影院老司| av免费播放网址| 一区二区日韩| 久久av.com| 中国a一片一级一片| 99视频精品在线| 9191国产视频| 色噜噜成人av在线| 国产一区二区三区三区在线观看| 亚洲黄色一区二区| 国产成人精品免费在线| 中文字幕在线亚洲三区| 日韩中文在线播放| 日韩精品免费看| 日韩少妇高潮抽搐| 国产成人精品免费| 毛片av在线播放| 国产精品亚洲欧美日韩一区在线 | 日韩欧美综合一区| 国精产品视频一二二区| 日韩精品免费视频人成| 蜜桃欧美视频| 一级毛片久久久| 日韩av中文字幕在线| 国产午夜小视频| 成人三级伦理片| 免费看日本黄色| 日韩视频一二区| 欧美大尺度激情区在线播放| 亚洲一区二区影视| 国产精品国产自产拍在线| 国产理论在线播放| 第九色区aⅴ天堂久久香| 国产精品6699| 亚洲s色大片| 欧美区在线观看| 亚洲不卡在线播放| 国产麻豆精品久久一二三| 先锋影音男人资源| 蜜桃在线一区| 国内精品免费午夜毛片| 日韩中文字幕观看| 精品久久久久久中文字幕| 极品粉嫩小仙女高潮喷水久久| 国产精品乱看| 欧美午夜精品久久久久免费视| 性欧美hd调教| 日韩中文字幕视频在线观看| 国产男女无套免费网站| 亚洲国产中文字幕在线视频综合| 久久久国产精品无码| 亚洲一区二区三区高清| 午夜欧美性电影| 精品视频成人| 久久久人成影片一区二区三区观看 | 亚洲国产精品人久久电影| 精品成人久久久| 国产性天天综合网| 亚洲天堂伊人网| 欧美日韩mv| 欧美高清视频一区| yy6080久久伦理一区二区| 久久久99免费视频| 蜜臀av免费在线观看| 色系网站成人免费| 欧美在线视频第一页| av在线播放成人| 欧美美女性视频| 亚洲激情网址| 亚洲精品久久久久久一区二区| 日本99精品| 欧洲亚洲免费视频| 黄色网页在线看| 亚洲免费人成在线视频观看| 91片黄在线观看喷潮| 精品久久久视频| 国产精品国产三级国产传播| 波多野结衣视频一区| 亚洲少妇第一页| 亚洲天堂黄色| 正在播放亚洲| 欧美人与牛zoz0性行为| 7777精品伊久久久大香线蕉语言| 澳门成人av网| 欧美乱大交xxxxx| 国产小视频免费在线观看| 日韩精品一区二| 国产精品高清无码| 性做久久久久久免费观看欧美| 毛片aaaaaa| www..com久久爱| 91在线第一页| 奇米色一区二区| 波多野结衣之无限发射| 99久久久久国产精品| 美女主播视频一区| 在线播放一区二区精品视频| 国产精品久久久久7777婷婷| 色在线中文字幕| 欧美大片在线影院| 超碰在线观看免费| 少妇高潮久久77777| 日本成人一区| 亚洲国产天堂久久综合网| 国产在成人精品线拍偷自揄拍| 日韩欧美国产激情| 日韩精品人妻中文字幕| 一区二区三区在线视频观看58| 国产精品视频在| 国产区在线观看成人精品| www.免费av| 99re热这里只有精品视频| 99久久久无码国产精品性波多 | 爱搞国产精品| 欧美高清一级大片| 宅男网站在线免费观看| 日韩中文字幕在线视频| 成人性生交大片免费看午夜| 国产午夜精品麻豆| 天天爽夜夜爽夜夜爽| 欧美精品一区二区三区久久久| 国产色综合视频| 欧美一区二区三区播放老司机| 91久久国语露脸精品国产高跟| 欧美视频精品在线| 在线观看你懂的网站| 色婷婷国产精品久久包臀| 国产一级片毛片| 一本久久a久久精品亚洲| 亚洲欧美精品一区二区三区| 日韩欧美精品网站| 黄色一级视频免费看| 欧美日韩综合视频| 五月天综合激情网| 日本高清无吗v一区| 天天干天天色综合| 色噜噜狠狠色综合欧洲selulu| jizz国产在线| 欧美三级三级三级爽爽爽| 在线观看免费视频一区| 欧美人与z0zoxxxx视频| 国产免费av电影| 欧美精品一区二| 五月婷婷六月丁香| 亚洲天堂成人在线| 尤物在线视频| 欧美肥老妇视频| 成人三级高清视频在线看| 91产国在线观看动作片喷水| 日本精品裸体写真集在线观看| 国产免费久久av| 亚洲日本va| 久久久www免费人成黑人精品| 最新国产一区| 在线观看欧美激情| 国产精品地址| 玩弄japan白嫩少妇hd| 麻豆国产精品777777在线| 久久精品无码一区二区三区毛片| 丁香六月综合激情| 波多野结衣a v在线| 国产精品久99| 五月天婷婷网站| 欧美日韩日日摸| 四虎在线视频免费观看| 亚洲免费人成在线视频观看| 黄色成人在线| 青草热久免费精品视频| 999久久久国产999久久久| 国产精品一区二区三区四区五区 | 国产精品美女久久久久| 蜜桃在线一区二区三区精品| 国产精品久久久久久久久久10秀| 野外做受又硬又粗又大视频√| 日韩经典一区二区| 丰满少妇xbxb毛片日本| 国产精品视频观看| 久久网中文字幕| 欧美色综合网站| 天堂成人在线视频| 精品国产一区二区在线| 一区二区乱码| 97免费高清电视剧观看| 欧美日韩中文字幕一区二区三区| 免费特级黄色片| 久久精品国产**网站演员| 中文在线一区二区三区| 亚洲欧美经典视频| 日韩熟女一区二区| 亚洲国产精品va在线看黑人动漫| 婷婷免费在线视频| 欧美一级电影久久| 久久久精品区| 亚洲一二三区在线| 亚洲欧美日韩一区在线观看| 日本一级大毛片a一| 中文字幕亚洲成人| 亚洲午夜无码久久久久| 精品亚洲男同gayvideo网站| 男人天堂亚洲天堂| 91在线视频导航| 三上亚洲一区二区| 日日碰狠狠丁香久燥| av一区二区三区在线| 精品在线视频免费观看| 91精品欧美综合在线观看最新| 国产日本在线| 日本一区二区不卡| 日韩有码一区| 亚洲美免无码中文字幕在线 | www在线观看免费视频| 五月激情综合网| 欧美视频在线观看一区二区三区| 美女av一区二区三区| 亚洲三级在线| 中文字幕久久综合| 久草中文综合在线| 肉色超薄丝袜脚交69xx图片| 欧美日韩一区在线观看| h视频网站在线观看| 国产91久久婷婷一区二区| 亚洲国产精品嫩草影院久久av| 成熟丰满熟妇高潮xxxxx视频| 成人aa视频在线观看| 日韩久久久久久久久| 亚洲风情亚aⅴ在线发布| 国产探花视频在线观看| 国产精品久久久久久久免费大片| 午夜欧美精品| 18深夜在线观看免费视频| 亚洲黄色片在线观看| 精品人妻久久久久一区二区三区| 欧美精品免费播放| 91久久精品无嫩草影院| 国产青草视频在线观看| 成人午夜激情视频| 日韩免费视频网站| 精品亚洲一区二区三区| 亚洲第一会所001| 一个色的综合| 国产激情视频一区二区三区欧美 | 亚洲av无一区二区三区| 欧美精品久久99| 羞羞网站在线看| 国产免费一区二区三区| 香蕉久久夜色精品| 人妻视频一区二区| 欧美猛男超大videosgay| 午夜成年人在线免费视频| 国产精品大全| 免费在线成人| 亚洲精品自拍视频在线观看| 日韩视频一区在线观看| 蜜桃视频www网站在线观看| 欧美日韩亚洲免费| 久久66热re国产| 国产无码精品视频| 亚洲欧美日韩一区在线| 四虎国产精品永久在线国在线| 狠狠噜天天噜日日噜| 91在线观看高清| 中文资源在线播放| 欧美另类在线观看| 国产欧美日韩| 永久av免费在线观看| 欧美日韩亚洲成人| 黄色免费在线观看| 六月婷婷久久| 国产在线播放一区| 亚洲黄色小说图片| 日韩一区二区在线视频| 久久香蕉精品香蕉| 伊人网在线综合| 午夜视频久久久久久| 95在线视频| 韩国精品一区二区三区六区色诱| 蜜臀av一区二区在线免费观看| 精品无码人妻一区二区三区品 | 久久99久久99精品蜜柚传媒| 久久99久久久久|