日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

扩展mysql_扩展mysql - 手把手教你写udf

發布時間:2023/12/4 数据库 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 扩展mysql_扩展mysql - 手把手教你写udf 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1 MySQL簡介

MySQL是最流行的開放源碼SQL數據庫管理系統,相對于Oracle,DB2等大型數據庫系統,MySQL由于其開源性、易用性、穩定性等特點,受到個人使用者、中小型企業甚至一些大型企業的廣泛歡迎,MySQL具有以下特點:

lMySQL是一種關聯數據庫管理系統,關聯數據庫將數據保存在不同的表中,而不是將所有數據放在一個大的倉庫內,這樣就增加了速度并提高了靈活性。

lMySQL軟件是一種開放源碼軟件。

lMySQL數據庫服務器具有快速、可靠和易于使用的特點。

lMySQL服務器工作在客戶端/服務器模式下,或嵌入式系統中。

l有大量可用的共享MySQL軟件。

2 MySQL內置函數

使用過MySQL的人都知道,MySQL有很多內置函數提供給使用者,包括字符串函數、數值函數、日期和時間函數等,給開發人員和使用者帶來了很多方便。下面給幾個例子:

l字符串函數

mysql> select ASCII('2');

+------------+

| ASCII('2') |

+------------+

|50 |

+------------+

打印字符的ASCII編碼。

l數值函數

mysql> SELECT LOG(10,100);

+-------------+

| LOG(10,100) |

+-------------+

|2 |

+-------------+

打印以10為底,100的對數值。

l日期和時間函數

mysql> SELECT CURDATE();

+------------+

| CURDATE()|

+------------+

| 2011-11-11 |

+------------+

打印當前的日期。

這里簡單舉幾個例子,如果想了解MySQL函數的全貌,請訪問Mysql官方手冊

3擴展MySQL函數------ UDF

MySQL的內置函數雖然豐富,但畢竟不能滿足所有人的需要,有時候我們需要對表中的數據進行一些處理而內置函數不能滿足需要的時候,就需要對MySQL進行一些擴展,幸運的是,MySQL給使用者提供了添加新函數的機制,這種使用者自行添加的MySQL函數就稱為UDF(User Define Function)。其實除了UDF外,使用者還可以將函數添加為MySQL的固有(內建)函數,固有函數被編譯進mysqld服務器中,稱為永久可用的,不過這種方式較添加UDF

復雜,升級維護都較為麻煩,這里我們不做討論。

無論你使用哪種方法去添加新函數,它們都可以被SQL聲明調用,就像ABS()或SUM()這樣的固有函數一樣。

3.1 UDF的特性

l函數能返回字符串,整數或實數。

l你可以定義一次作用于一行的簡單函數,或作用于多行的組的集合函數。

l提供給函數的信息使得函數可以檢查傳遞給它們的參量的數目和類型。

l你可以讓MySQL在將某參量傳遞給函數之前強制其為某一類型。

l你可以表示函數返回NULL或發生錯誤。

3.2 CREATE FUNCTION/DROP FUNCTION語法

CREATE [AGGREGATE] FUNCTIONfunction_nameRETURNS {STRING|INTEGER|REAL}

SONAMEshared_library_name

DROP FUNCTIONfunction_name

一個自定義函數(UDF)就是用一個象ABS()或SUM()這樣的固有(內建)函數一樣作用的新函數去擴展MySQL。

function_name是用在SQL聲明中以備調用的函數名字。RETURNS子句說明函數返回值的類型。shared_library_name是共享目標文件的基本名,共享目標文件含有實現函數的代碼。該文件必須位于一個能被你系統的動態連接者搜索的目錄里。

你必須有mysql數據庫的INSERT權限才能創建一個函數,你必須有mysql數據庫的DELETE權限才能撤銷一個函數。這是因為CREATE FUNCTION往記錄函數名字,類型和共享名的mysql.func系統表里添加了一行,而DROP FUNCTION則是從表中刪掉這一行。

值得注意的是,要使得UDF機制能夠起作用,必須使用C或者C++編寫函數,你的系統必須支持動態加載,而且你必須是動態編譯的mysqld(非靜態)。

3.3定義UDF

對于每個你想要使用在SQL聲明中的函數,你應該定義相應的C(或C++)函數。

你為xxx()編寫來實現接口的C/C++函數如下:

lxxx() (必有)

主函數。這是函數結果被計算的地方。SQL函數數據類型與C/C++函數返回類型的對應關系如下:

SQL類型

C/C++類型

STRING

char *

INTEGER

long long

REAL

double

lxxx_init() (可選)

對xxx()的初始化函數。它可以被用來:

檢查傳遞給xxx()的參量數目。

檢查參量是否為必需的類型,或者,除此之外,在主函數被調用的時候告訴MySQL將參量強制為想要的類型。

分配主函數需要的內存。

指定結果的最大長度。

指定(對于REAL函數)小數的最多位數。

指定結果是否可以為NULL。

lxxx_deinit()(可選)

對xxx()的去初始化函數。它釋放初始化函數分配的內存。

當SQL聲明調用XXX()時,MySQL調用初始化函數xxx_init(),讓它執行必要的設置,比如,檢查參量或分配內存。如果xxx_init()返回一個錯誤,SQL聲明會退出并給出錯誤信息,而主函數和去初始化函數并沒有被調用。否則,主函數xxx()對每一行都被調用一次。所有行都處理完之后,調用去初始化函數xxx_deinit()執行必要的清除。

對于象SUM()一樣工作的集合函數,你也必須提供如下的函數:

lxxx_clear()(在5.1版本中必須)

對一個新組重置當前集合值為初試集合值,但不插入任何參量。

lxxx_add()(必須)

添加參量到當前集合值。

MySQL按下列操作來處理集合UDF:

1.調用xxx_init()讓集合函數分配它需要用來存儲結果的內存。

2.按照GROUP BY表達式來排序表。

3.為每個新組中的第一行調用xxx_clear()函數。

4.為屬于同組的每一個新行調用xxx_add()函數。

5.當組改變時或每組的最后一行被處理完之后,調用xxx()來獲取集合結果。

6.重復,以上3步直到所有行被處理完。

7.調用xxx_deinit()函數去釋放UDF分配的內存。

所有函數必須時線程安全的,這不僅對主函數,對初始化和去初始化函數也一樣,也包括集合函數要求的附加函數。這個要求的一個結果就是,你不能分配任何變化的全局或靜態變量。如果你需要內存,你可以在xxx_init()函數分配內存,然后在xxx_deinit()函數釋放掉。

3.3.1主要數據結構

UDF_INIT

typedef struct st_udf_init

{

my_bool maybe_null;/* 1 if function can return NULL */

unsigned int decimals;/* for real functions */

unsigned long max_length;/* For string functions */

char*ptr;/* free pointer for function data */

my_bool const_item;/* 0 if result is independent of arguments */

} UDF_INIT;

lmy_bool maybe_null

如果xxx()能返回NULL,xxx_init()應使maybe_null為1。其默認值是1。

lunsigned int decimals

小數位數。默認值是傳到主函數的參量里小數的最大位數。(例如,如果函數傳遞1.34, 1.345,和1.3,那么默認值為3,因為1.345有3位小數。

lunsigned int max_length

結果的最大長度。max_length的默認值因函數的結果類型而異。對字符串函數,默認值是結果的最大長度。對整型函數,默認是21位。對實型函數,默認是13再加上initid->decimals指示的小數位數。(對數字函數,長度包含正負號或者小數點符)。

如果想返回團值,你可以把max_length設為從65KB到16MB。這個內存不會被分配,但是如果有臨時數據需要存儲,這個設置了的值被用來決定使用哪種列的類型。

lchar *ptr

函數可以用作本身目的的指針。比如,函數可以用initid->ptr來在分配了的內存內部通訊。xxx_init()應該分配內存,并指派給這個指針:

initid->ptr = allocated_memory;

在xxx()和xxx_deinit()中,借用initid->ptr來使用或釋放內存。

UDF_ARGS

enum Item_result /*返回結果類型*/

{

STRING_RESULT=0,

REAL_RESULT,

INT_RESULT,

ROW_RESULT,

DECIMAL_RESULT

};

typedef struct st_udf_args

{

unsigned int arg_count;/* Number of arguments */

enum Item_result *arg_type;/* Pointer to item_results */

char **args;/* Pointer to argument */

unsigned long *lengths;/* Length of string arguments */

char *maybe_null;/* Set to 1 for all maybe_null args */

char **attributes;/* Pointer to attribute name */

unsigned long *attribute_lengths;/* Length of attribute arguments */

} UDF_ARGS;

lunsigned int arg_count

參數個數。如果你需要你的函數帶著某個數目的參量被調用,在初始化函數檢查這個值,例如:

if (args->arg_count != 2)

{

strcpy(message,"XXX() requires two arguments");

return 1;

}

lenum Item_result *arg_type

參數類型列表。要確信一個參量是給定類型的,并且如果不是的話就返回一個錯誤,請檢查初始化函數中的arg_type數列。比如:

if (args->arg_type[0] != STRING_RESULT ||

args->arg_type[1] != INT_RESULT)

{

strcpy(message,"XXX() requires a string and an integer");

return 1;

}

要求你函數的參量是某一類型的另一方法是,使用初始化函數設置arg_type元素為你想要的類型。對所有對xxx()的調用而言,這會導致MySQL強制參量為這些類型。比如,要指定頭兩個參量強制成字符串和整數,在xxx_init()中分別:

args->arg_type[0] = STRING_RESULT;

args->arg_type[1] = INT_RESULT;

lchar **args參數列表

對主函數的每次調用,args->args包含為每個當前處理的行傳遞的實際參量。

如下使用參量i的函數:

給一個STRING_RESULT型的參量作為一個字符串加一個長度,可以允許所有二進制數或任意長度的數處理。字符串內容作為args->args[i],而字符串長度為args->lengths[i]。你不能采用null結尾的字符串。

對一個INT_RESULT型的參量,你必須轉換args->args[i]為一個long long值:

long long int_val;

int_val = *((long long*) args->args[i]);

對一個REAL_RESULT型參量,你必須轉換args->args[i]為一個雙精度值:

doublereal_val;

real_val = *((double*) args->args[i]);

lunsigned long *lengths

對初始化函數,lengths數列表示對每個參量的最大字符串長度。你不要改變它。對主函數的每次調用,lengths包含了對當前處理行傳遞的任何字符串參量的實際長度。對于INT_RESULT或REAL_RESULT類型的參量,lengths仍包含參量的最大長度(對初始化函數)。

3.3.2簡單函數

這里說明簡單SQL函數的C/C++主函數xxx()的編寫,注意返回值和參數會有所不同,這取決于你說明的SQL函數xxx()在CREATE FUNCTION聲明中返回的是STRING,INTEGER類型還是REAL類型。

對于STRING型函數:

char *xxx(UDF_INIT *initid, UDF_ARGS *args,

char *result, unsigned long *length,

char *is_null, char *error);

對于INTEGER型函數:

long long xxx(UDF_INIT *initid, UDF_ARGS *args,

char *is_null, char *error);

對于REAL型函數:

double xxx(UDF_INIT *initid, UDF_ARGS *args,

char *is_null, char *error);

初始化和去初始化函數如下說明:

my_bool xxx_init(UDF_INIT *initid, UDF_ARGS *args, char *message);

void xxx_deinit(UDF_INIT *initid);

initid參數被傳遞給所有的三個函數。它指向UDF_INIT結構,這個結構被用來在函數之間交換信息。

3.3.3集合函數

這里介紹創建集合UDF之時需要定義的不同函數。

lxxx_reset()

當MySQL在一個新組中發現第一行時調用這個函數。它對這個組重置任何內部總和變量,然后使用給定的UDF_ARGS參量作為內部總和值的第一個值。如下說明xxx_reset()函數:

char *xxx_reset(UDF_INIT *initid, UDF_ARGS *args,

char *is_null, char *error);

在MySQL5.1版中UDF接口不需要或不使用xxx_reset()函數,而是使用xxx_clear()函數作為替代。但是如果你想讓UDF也能在老版本的服務器上運行,你也可以定義xxx_reset()和xxx_clear()函數。(如果你使用了這兩個函數,xxx_reset()函數在很多情況下可以通過調用函數來內部實現,即調用xxx_clear()函數重置所有變量,然后添加UDF_ARGS參量作為組的第一個值。)

lxxx_clear()

當MySQL需要重置總和結果時調用此函數。對每一個新組,在開始之時調用它,但是它也可以被調用來為一個沒有匹配行在其中的查詢重置值。如下說明xxx_clear():

char *xxx_clear(UDF_INIT *initid, char *is_null, char *error);

在調用xxx_clear()之前is_null被設置指向CHAR(0)。

如果發生錯誤,你可以存儲一個值在error參量指向的變量中。error指向一單字節變量,而不是一個字符串緩沖區。

xxx_clear()是MySQL 5.1必須的。

lxxx_add()

為同組所有的行調用這個函數。你應該用它在UDF_ARGS參量中向內部總和變量加值。

char *xxx_add(UDF_INIT *initid, UDF_ARGS *args,

char *is_null, char *error);

對集合UDF而言xxx()函數應該用與非集合UDF一樣的方法來說明。

對一個集合UDF,MySQL在組內所有行被處理之后調用xxx()函數。這里你應該一般不會接觸到它的UDF_ARGS參量,但是取而代之地根據內部總和變量返回給你值。

is_null和error的指針參量和所有到xxx_reset(), xxx_clear(), xxx_add()和xxx()調用一樣。你可以用這個來提醒你獲取一個錯誤或無論xxx()是否返回NULL的一個結果。你不能把一個字符串存到error!error指向單字節變量而不是字符串緩沖區。

*is_null對每一個組都重置(調用xxx_clear()前),*error從不重置。

如果xxx()返回時,*is_null或*error被設置,MySQL返回NULL作為組函數的結果。

3.3.4錯誤處理

如果沒有錯誤發生,初始化函數應該返回0,否則就返回1。如果有錯誤發生,xxx_init()應該在message參數存儲一個以null結尾的錯誤消息。該消息被返回給客戶端。消息緩沖區是MYSQL_ERRMSG_SIZE字符長度,但你應該試著把消息保持在少于80個字符,以便它能適合標準終端屏幕的寬度。

對于long long和double類型的函數,主函數xxx()的返回值是函數值。字符函數返回一個指向結果的指針,并且設置*result和*length為返回值的內容和長度。例如:

memcpy(result, "result string", 13);

*length = 13;

被傳給xxx()函數的結果緩沖區是255字節長。如果你的結果適合這個長度,你就不需要擔心對結果的內存分配。

如果字符串函數需要返回一個超過255字節的字符串,你必須用malloc()在你的xxx_init()函數或者xxx()函數里為字符串分配空間,并且在xxx_deinit()函數里釋放此空間。你可以將已分配內存存儲在UDF_INIT結構里的ptr位置以備將來xxx()調用。

要在主函數中指明一個NULL的返回值,設置*is_null為1:

*is_null = 1;

要在主函數中指明錯誤返回,設置*error為1:

*error = 1;

如果xxx()對任意行設置*error為1,對于任何XXX()被調用的語句處理的當前行和隨后的任意行,該函數值為NULL(甚至都不為隨后的行調用xxx())。

4范例

4.1編譯安裝

安裝mysql開發包

[root@rocket mysql_udf]# yum -y install mysql-devel

編譯udf鏈接庫

代碼:udf_str.cpp

#include #include#include#include#include#include

extern "C"{//str_reverse

my_bool str_reverse_init(UDF_INIT* initid, UDF_ARGS* args, char*message);void str_reverse_deinit(UDF_INIT*initid);char* str_reverse(UDF_INIT* initid, UDF_ARGS* args, char* result, unsigned long* length, char* is_null, char *error);//LengthAll

my_bool mysum_init(UDF_INIT* initid, UDF_ARGS* args, char*message);void mysum_deinit(UDF_INIT*initid);void mysum_reset(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error);void mysum_clear(UDF_INIT *initid, char *is_null, char *error);void mysum_add(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error);long long mysum(UDF_INIT *initid, UDF_ARGS *args, char *result, unsigned long *length, char *is_null, char *error);

}char* StrData = 0;int gSum = 0;//str_reverse ==================================================

my_bool str_reverse_init(UDF_INIT* initid, UDF_ARGS* args, char*message)

{if (args->arg_count != 1)

{

strcpy(message,"wrong number of arguments: str_reverse() requires one argument");return 1;

}if (args->arg_type[0] !=STRING_RESULT)

{

strcpy(message,"str_reverse() requires a string as parameter");return 1;

}

StrData= (char*)malloc(4096);

memset(StrData,0, 4096);

initid->maybe_null = 1;

initid->max_length = 32;

initid->ptr =StrData;return 0;

}void str_reverse_deinit(UDF_INIT*initid)

{free(StrData);

}char* str_reverse(UDF_INIT* initid, UDF_ARGS* args, char* result, unsigned long* length, char* is_null, char *error)

{if (args->arg_type[0] ==STRING_RESULT)

{if (strlen(args->args[0]) > 256)

{

strncpy(StrData, args->args[0], 4096);

StrData[4096-1] = 0;

std::reverse(StrData, StrData+strlen(StrData));returnStrData;

}else{

strncpy(result, args->args[0], 256);

result[256-1] = 0;

std::reverse(result, result+strlen(result));*length = (unsigned long)strlen(result);returnresult;

}

}returnNULL;

}//LengthAll ==================================================

my_bool mysum_init(UDF_INIT* initid, UDF_ARGS* args, char*message)

{if (args->arg_count != 1)

{

strcpy(message,"wrong number of arguments: mysum() requires one argument");return 1;

}if (args->arg_type[0] !=INT_RESULT)

{

strcpy(message,"wrong argument type of arguments: mysum() requires int");return 1;

}

gSum= 0;return 0;

}void mysum_deinit(UDF_INIT*initid)

{

}void mysum_reset(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)

{

gSum= 0;

}void mysum_clear(UDF_INIT *initid, char *is_null, char *error)

{

gSum= 0;

}void mysum_add(UDF_INIT *initid, UDF_ARGS *args, char *is_null, char *error)

{

gSum+= *(int*)(args->args[0]);

}long long mysum(UDF_INIT *initid, UDF_ARGS *args, char *result, unsigned long *length, char *is_null, char *error)

{returngSum;

}

[root@rocket mysql_udf]# g++ -I/usr/include/mysql -shared -fPIC -o udf_str.so udf_str.cpp

查找插件路徑

安裝插件函數

DROP FUNCTION IF EXISTS str_reverse;

DROP FUNCTION IF EXISTS mysum;

CREATE FUNCTION str_reverse RETURNS string SONAME 'udf_str.so';

CREATEAGGREGATEFUNCTION mysum RETURNSINTEGERSONAME 'udf_str.so';

注意這里的返回值不能寫錯,不然運行的時候mysql服務器會崩潰!

查看安裝結果

4.2運行

運行str_reverse

運行mysum,先創建一些數據

mysql> create database test;

mysql> use test;

mysql> CREATE TABLE salary( name varchar(64) NOT NULL DEFAULT '' COMMENT 'name', salary int(11) NOT NULL DEFAULT 0 COMMENT 'salary', primary key(name) )ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT 'test';

mysql> insert into salary values ('zhangsan', 11380), ('lisi', 12000), ('wangwu', 8789);

mysql> select mysum(name) from salary;

ERROR 1123 (HY000): Can't initialize function 'mysum'; wrong argument type of arguments: mysum() requires int

這里故意使用name為參數,可以看到我們在程序里打印的錯誤信息。

執行正確的語句

可以看到mysum實現了和內置函數sum一樣的功能。

總結

以上是生活随笔為你收集整理的扩展mysql_扩展mysql - 手把手教你写udf的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

香蕉色综合 | 欧美精品久久久久久久久久丰满 | 国产毛片久久久 | 国产精品手机在线 | 久久精品这里热有精品 | 国产精品欧美久久久久三级 | 免费在线观看中文字幕 | 夜夜爽www | 精品视频99 | 六月丁香激情综合色啪小说 | 精品久久亚洲 | 一区二区三区视频 | 日韩三级免费观看 | 午夜精品久久久久久久99无限制 | 色婷婷 亚洲 | 五月天,com| 成人片在线播放 | av免费观看网址 | 五月婷在线播放 | 日韩高清不卡一区二区三区 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 国产91精品高清一区二区三区 | 午夜在线看片 | 国产成人一区二区在线观看 | 国产精品免费麻豆入口 | 欧美午夜性生活 | 欧美日韩视频在线观看一区二区 | av丝袜在线 | 菠萝菠萝蜜在线播放 | 中文字幕一区二区三区四区久久 | 日本久久久久久久久久久 | 国产色区| 亚洲人成精品久久久久 | 在线观看亚洲免费视频 | 欧美最猛性xxxx | 国产视频一二区 | 亚洲视频,欧洲视频 | 国产福利中文字幕 | 午夜精品麻豆 | 在线日本看片免费人成视久网 | 日韩网站在线观看 | 国产日韩欧美视频 | 亚洲欧美视频在线观看 | av中文资源在线 | 欧美另类性 | zzijzzij亚洲成熟少妇 | 国产一级精品视频 | 五月婷婷激情六月 | 在线观看国产v片 | 国产一区二区在线播放 | 99视频精品视频高清免费 | 久久综合九色综合久99 | 日韩精品中文字幕在线不卡尤物 | 中文字幕免费 | 国产又粗又猛又爽又黄的视频免费 | 国产成人性色生活片 | 日韩电影一区二区在线观看 | 亚洲免费a | 在线看中文字幕 | 国产精品久久久久一区二区 | 在线免费观看麻豆视频 | 久青草电影 | 国产免费专区 | 亚洲成人av在线 | 欧美一级片免费在线观看 | 狠狠操电影网 | 又黄又爽的视频在线观看网站 | 日韩视频免费 | 五月婷婷在线视频观看 | 欧美日韩在线网站 | 免费在线精品视频 | 国产精品原创视频 | 欧美精品一区二区在线观看 | 亚洲精品美女 | 免费观看v片在线观看 | 久久久精品国产免费观看同学 | 国产永久免费观看 | 久久久久区 | 国产91精品看黄网站 | 中文字幕视频观看 | 91精品国产欧美一区二区成人 | 欧美日韩性生活 | a极黄色片 | 91av视屏| 精品视频久久 | 9色在线视频 | 开心综合网 | 天天射天天 | 亚洲成人软件 | 蜜桃视频色 | 成年人免费在线看 | 日韩高清一二区 | 久久久受www免费人成 | 免费观看91视频大全 | 免费在线观看毛片网站 | 国内一区二区视频 | 久久精品一区二区 | 91麻豆精品一区二区三区 | 九九久久久久99精品 | 日韩中文字幕电影 | 中文字幕av在线播放 | 69av在线播放 | 国产精品久久久久久久毛片 | 在线成人av| 日韩精品久久一区二区 | 国产九九精品视频 | 91视频 - v11av | 精品国产一区二区三区久久久 | 日韩三级久久 | 精品国产电影一区二区 | 亚洲播放一区 | 久久韩国免费视频 | 午夜久久久久久久久 | 日韩二区三区在线观看 | 国产 在线观看 | 狠狠色丁香婷婷综合久小说久 | 碰天天操天天 | 亚洲永久精品视频 | 啪啪激情网 | 狠狠综合久久 | 久久国产精品久久w女人spa | 日韩视频区 | 久久精品视频18 | 国产精品视频免费观看 | 一区二区三区不卡在线 | 91视频com | 啪啪午夜免费 | 久久精品91视频 | 999电影免费在线观看2020 | 国产成人亚洲精品自产在线 | 又爽又黄又无遮挡网站动态图 | 欧美一二在线 | 97视频中文字幕 | 6080yy精品一区二区三区 | 日韩精品免费专区 | 91亚洲国产 | 波多野结衣视频在线 | 久久乐九色婷婷综合色狠狠182 | 久久综合日 | 天堂av高清 | 色婷婷综合久久久久中文字幕1 | 久久精品国产v日韩v亚洲 | 伊人网综合在线观看 | 色婷婷综合久久久 | 日韩大片在线观看 | 日韩在线高清视频 | 国产明星视频三级a三级点| 亚洲另类久久 | 天天爱综合 | 婷婷激情五月综合 | 狠狠干 狠狠操 | 欧美日韩视频免费看 | 欧美精品做受xxx性少妇 | 一级黄网| 精品亚洲免a | 中文字幕第 | 在线免费黄色av | 天天天天天天操 | 日韩av电影网站在线观看 | 天天狠狠干| 97精品超碰一区二区三区 | 国产女v资源在线观看 | 久久久综合九色合综国产精品 | 四虎国产精 | 日韩欧美一区二区三区在线观看 | 日韩在线视频看看 | 天天干夜夜夜 | 黄色精品网站 | 美女黄视频免费 | 香蕉视频网站在线观看 | 一级做a爱片性色毛片www | 天天干天天射天天插 | 麻豆国产精品视频 | 美女在线观看av | 精品亚洲国产视频 | 久草电影在线观看 | 欧美一区二视频在线免费观看 | 国产大片黄色 | 久久久久免费精品国产 | 天天干天天操天天 | 亚洲黄色片一级 | 韩国精品在线观看 | 99在线视频免费观看 | 九九久久久久久久久激情 | 国产精品一区免费看8c0m | 超级碰99 | 日本激情视频中文字幕 | 香蕉影院在线播放 | 黄色片软件网站 | 久久视频精品 | 久久久国产一区二区三区四区小说 | a久久久久久 | 日韩中文字幕在线不卡 | 久久久久久久久福利 | 免费福利片2019潦草影视午夜 | 欧美精品中文在线免费观看 | 国际精品久久久 | 97超碰人人网 | 亚洲一二区视频 | 日本黄色一级电影 | 日日夜夜噜 | 国产精品不卡一区 | 亚洲情婷婷 | av超碰免费在线 | 国产精品成人久久久久 | 国产裸体视频bbbbb | 国产高清视频色在线www | 成人一区二区三区在线观看 | 日韩免费一区 | 91亚色视频在线观看 | 亚洲精品中文字幕视频 | 日韩系列 | 欧美日韩破处 | 欧美精品久久久久久久 | 毛片视频电影 | 国产黄色精品视频 | 黄色高清视频在线观看 | 蜜臀av性久久久久蜜臀av | 成年人视频在线观看免费 | 视频在线观看一区 | 国产一区二区精品久久91 | 不卡的av在线播放 | 欧美日韩国内在线 | 色婷婷久久一区二区 | 久久久国产精品免费 | 久热爱| 欧美日韩视频在线观看一区二区 | 免费亚洲视频在线观看 | 香蕉视频最新网址 | 久草在线一免费新视频 | 成人一级片免费看 | 天天爽人人爽夜夜爽 | 国产精品黄色影片导航在线观看 | 国产99自拍 | 97色se | 久久成人免费 | 国产韩国日本高清视频 | 欧美精品中文在线免费观看 | www.操.com| 午夜精品福利影院 | 久草在线视频首页 | 日韩成人xxxx | 99久久99久久精品免费 | 在线成人中文字幕 | 亚洲精品资源在线 | 三级免费黄色 | 黄色片网站免费 | 欧美另类z0zx | 欧美一级电影在线观看 | 69绿帽绿奴3pvideos | 婷婷九月丁香 | 成人av电影在线播放 | 天堂视频一区 | 人人干人人上 | 91免费在线视频 | 婷婷久久一区二区三区 | 91av大全| 黄色网址av| 成人a级黄色片 | 久草在线网址 | 蜜桃麻豆www久久囤产精品 | 嫩草伊人久久精品少妇av | 免费成人黄色片 | 成人教育av | 9992tv成人免费看片 | 国产黄色电影 | 精品亚洲午夜久久久久91 | 欧美成人在线免费观看 | 国产亚洲视频系列 | 嫩模bbw搡bbbb搡bbbb | 黄色片视频免费 | 亚洲天堂视频在线 | 色播99| 天天拍天天爽 | 黄色国产在线观看 | 91在线看| 黄色三级在线 | 亚洲不卡av一区二区三区 | 久草视频在线播放 | 视频在线一区 | 天天干天天干天天干 | 久久免费的精品国产v∧ | 综合网天天射 | 99热99re6国产在线播放 | 国产高清av免费在线观看 | 一区二区三区精品在线 | 最新国产在线 | 国产99久久久欧美黑人 | 永久免费视频国产 | 最新色站 | 久久久久久久国产精品 | 国产高清在线精品 | 91精品久久久久久综合乱菊 | 国产视频 亚洲精品 | 国语精品视频 | 永久免费精品视频网站 | 中文字幕在线观看一区 | 99在线高清视频在线播放 | 日韩免费观看视频 | japanesexxxhd奶水| 日韩免费电影一区二区三区 | 日本精品视频在线观看 | 国产成人一区二区啪在线观看 | 操天天操 | 国产自偷自拍 | 国产高清免费av | 精品久久久久久久久久久久久久久久久久 | 成人黄色电影视频 | 亚洲三级在线播放 | 99久久网站| 久久这里只有精品1 | 国产在线免费 | 四虎天堂 | 国产高清99 | 亚洲精品五月 | 婷婷丁香激情网 | 在线一二区 | 色综合五月 | 在线亚洲欧美视频 | 在线观看亚洲电影 | 啪啪免费视频网站 | 精品国产亚洲在线 | 99久久精品视频免费 | 四虎影视精品 | 久久久精品一区二区 | 激情在线五月天 | 国产美女精品 | 国产亚洲精品中文字幕 | 亚洲精品国产电影 | 日韩电影在线一区 | 99色在线播放 | 国产成人综 | 久久av福利 | 国产精品日韩久久久久 | 福利视频网址 | 黄色三几片| 精品主播网红福利资源观看 | 日日干天天射 | 色停停五月天 | 中文字幕乱偷在线 | 综合国产在线 | 91色吧 | 国产中文字幕三区 | 亚洲区视频在线观看 | 久久久精品国产一区二区电影四季 | 成人久久久久久久久久 | 最近能播放的中文字幕 | 亚洲成aⅴ人在线观看 | 久久永久免费 | 久久久影院官网 | 毛片网在线观看 | 五月婷婷久草 | 中文字幕二区在线观看 | www.狠狠色.com | 国产 视频 久久 | 亚洲精品国产视频 | 国产亚洲婷婷免费 | 大荫蒂欧美视频另类xxxx | 午夜精品久久久久久久99 | 免费观看黄 | 91视频观看免费 | 手机成人在线电影 | 日韩欧美成 | 一区二区三区av在线 | 免费av网站观看 | 97超视频免费观看 | 久久激情精品 | 国产永久免费高清在线观看视频 | 日韩av有码在线 | 成人片在线播放 | 国产在线国偷精品产拍 | 久久久久伊人 | 日b视频在线观看网址 | 一区二区三区日韩精品 | 亚洲黄色av | 西西大胆免费视频 | 91av视频播放 | 黄色小说在线观看视频 | 天天拍天天爽 | 久草视频在线免费 | 日韩成人在线一区二区 | 免费a v在线 | 日韩特级黄色片 | 一区二区三区免费看 | 国产福利午夜 | 波多野结衣视频一区二区三区 | 亚洲区视频在线观看 | 亚洲国产精品va在线看黑人动漫 | 欧美一区日韩一区 | 免费碰碰 | 五月开心色| 中文字幕日本在线 | 亚洲成人资源在线观看 | 天天曰天天| 久久久影视 | 99精品国自产在线 | 国产精品a成v人在线播放 | 国产精品美女网站 | 日韩精品一区二区三区在线视频 | 日韩精品欧美一区 | 久久在线免费观看 | 国产一级一片免费播放放 | 在线免费观看国产视频 | 国产精品成人一区二区 | 97精品国产97久久久久久免费 | 91看片淫黄大片在线播放 | 日韩国产欧美在线播放 | 精品一区二区av | 黄色小说免费在线观看 | 中文字幕一区二区三区四区在线视频 | 日韩久久久久久久久久久久 | 亚洲精品国产精品国自 | 超碰人人草 | 超碰人人在线观看 | 亚洲精品字幕在线 | 在线免费黄色av | 91在线色 | 97人人模人人爽人人喊中文字 | 欧美日韩高清一区二区三区 | 日韩欧美一区二区三区视频 | 超碰人人在 | 天天婷婷 | 亚洲精品久久视频 | 最新国产精品拍自在线播放 | 九九视频在线观看视频6 | 成人免费观看网址 | 日本在线观看中文字幕 | 国产精品国产三级国产aⅴ无密码 | 日韩精品久久中文字幕 | 97人人精品 | 国产一区二区三区在线 | 色综合色综合色综合 | 日韩欧美精品一区二区 | 欧美aa一级 | 亚洲国产黄色片 | 91精品国产自产在线观看永久 | 国产精品无 | 福利视频一区二区 | 欧美a级在线播放 | 久久久视屏 | 亚洲精品在线网站 | 亚洲播播 | 91视频国产高清 | 色噜噜日韩精品欧美一区二区 | 久久亚洲欧美日韩精品专区 | 久久久国产影视 | 国内久久久| 97超级碰碰碰视频在线观看 | 91精品国产一区二区三区 | 国产91精品一区二区绿帽 | 日韩在线网 | 国产精品2019 | 精品xxx| 一区二区三区在线免费播放 | 国产成人久久av977小说 | 国产一区二区三区免费观看视频 | 国产综合在线观看视频 | 成人精品福利 | 99久久精品国产免费看不卡 | 91.麻豆视频 | 亚洲国产片色 | av成人免费观看 | 国产精品 国产精品 | 91av福利视频 | 中文字幕欲求不满 | 婷婷丁香激情网 | www.久久婷婷 | 伊人久久影视 | 精品麻豆入口免费 | 女人18片毛片90分钟 | 国产成人av | 亚洲天天干 | 五月天色站 | 成人一区二区三区中文字幕 | 国产免码va在线观看免费 | 最新成人av | 亚洲成人精品久久久 | av片在线看 | 99精品国产一区二区 | 黄色动态图xx | 99久久99久久综合 | 国产中文字幕av | 五月激情丁香图片 | 色噜噜日韩精品欧美一区二区 | 久久免费国产精品 | 一级欧美日韩 | 中文字幕丝袜美腿 | 天天干天天做 | 99热精品久久 | 黄网站www | 韩国av免费| 91成版人在线观看入口 | 国产午夜剧场 | 日本九九视频 | 久久综合欧美精品亚洲一区 | 亚洲成aⅴ人在线观看 | 最新不卡av| 九九九视频精品 | 国产又粗又猛又黄 | 国产精品国产三级国产aⅴ无密码 | 日韩av电影网站在线观看 | 欧洲精品视频一区 | 国产精品成久久久久三级 | 亚洲视频网站在线观看 | 欧美极品在线播放 | 91大神电影| 精品福利网站 | 亚洲精品av在线 | 亚洲日本黄色 | 欧美日韩啪啪 | 丁香婷婷激情啪啪 | 久久狠狠亚洲综合 | 天天色天天 | 天天草夜夜 | 欧美日韩精品电影 | 成人黄色在线视频 | 国产成人99av超碰超爽 | 国产精品一区二区吃奶在线观看 | 亚洲精品国久久99热 | 婷婷丁香综合 | 少妇18xxxx性xxxx片 | 亚洲精品视频网站在线观看 | 免费看片黄色 | 五月天婷亚洲天综合网精品偷 | 人人草天天草 | 久久人人97超碰com | 久久久久麻豆 | 国产91国语对白在线 | 欧美久久久久久久久久久久久 | 国产又粗又长又硬免费视频 | 欧美三级在线播放 | 国产精品久久久久久久久久白浆 | 国产一区在线免费观看视频 | 精品一区二三区 | 国产高清在线免费观看 | 久艹视频免费观看 | 国产精品资源 | 国产麻豆电影在线观看 | 婷婷深爱激情 | 国产真实在线 | 久草在线视频在线 | 激情 亚洲 | 我要色综合天天 | 蜜臀av夜夜澡人人爽人人 | 精品福利在线视频 | 亚洲国产精品激情在线观看 | 天堂在线免费视频 | 91精品久久久久久久久 | 永久免费看av| 夜夜骑首页 | 亚洲爽爽网 | 国产va饥渴难耐女保洁员在线观看 | 麻豆影视网站 | 欧美日韩国产欧美 | 亚洲成年人av | av成人在线观看 | 亚洲精品美女在线观看播放 | 一区二区电影在线观看 | 欧美日韩一级久久久久久免费看 | 五月婷婷另类国产 | 西西www4444大胆在线 | 丁香在线视频 | 久久深爱网 | 久久激情影院 | 日韩精品久久久久 | 亚洲人在线7777777精品 | 操操操日日日干干干 | 日韩精品免费在线播放 | 国产精品破处视频 | 少妇bbw揉bbb欧美 | 国产精品免费视频网站 | 色国产在线 | 中文视频一区二区 | 色诱亚洲精品久久久久久 | 国产资源网 | 日本不卡123区 | 黄网站免费看 | 96视频免费在线观看 | 丰满少妇对白在线偷拍 | 日韩三级免费 | 成人小视频免费在线观看 | www.色五月 | 97精品一区二区三区 | 国精产品999国精产品视频 | 天天操比 | 国产美女在线观看 | 精品视频在线免费观看 | av网站免费线看精品 | 色婷婷丁香 | 国产成人一二三 | 国产精品视频全国免费观看 | 91片在线观看 | 久久成年人 | 婷婷爱五月天 | 久久久在线免费观看 | 国产精品久久久久久久久久久不卡 | 最近2019好看的中文字幕免费 | 婷婷亚洲综合五月天小说 | 在线观看黄色免费视频 | 国产精品普通话 | 人人插人人插 | 亚洲一区动漫 | 视频一区在线免费观看 | 久久久久国产精品午夜一区 | 久久国产品 | 免费观看成人网 | 国产中文字幕91 | 久久久久国产精品免费 | 日韩一区精品 | 亚州精品在线视频 | 久久精品视频免费观看 | 国产18精品乱码免费看 | www.婷婷色| 色国产精品一区在线观看 | 欧美在线91| 人人爽人人爽人人爽学生一级 | 夜夜骑天天操 | av丝袜制服 | 国产免费中文字幕 | 国产精品免费小视频 | 国产亚洲欧美在线视频 | 国产在线观看一 | 中文字幕在线一二 | 狠狠操夜夜 | 日韩电影在线观看一区二区三区 | 99国产高清 | 在线天堂日本 | 亚洲狠狠干| 又黄又爽又无遮挡的视频 | 欧美成人一二区 | 97超碰总站 | 色网站在线免费观看 | 免费视频一区 | a在线v| 欧美亚洲专区 | 天天综合精品 | 超碰在线99 | 精品国产一区二区三区不卡 | 92精品国产成人观看免费 | 精品一区二区6 | 中文字幕999| 国产精品久久一区二区三区不卡 | 97人人澡人人爽人人模亚洲 | 区一区二区三在线观看 | 深爱婷婷久久综合 | 日本在线观看一区二区三区 | 久久黄色网页 | 国产黄色免费 | 91精彩在线视频 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 91在线国内视频 | 日韩com | 国产精品不卡 | 国产成人一区二区三区电影 | 国产丝袜制服在线 | 亚洲伊人第一页 | 五月天伊人网 | 亚洲国产经典视频 | 97精品视频在线播放 | 香蕉网站在线观看 | 91精品视频一区二区三区 | 日韩极品在线 | 91av影视| 久久伊人爱 | 久久影视网| 免费av大片 | 五月激情丁香婷婷 | 国产成人高清在线 | 国产.精品.日韩.另类.中文.在线.播放 | 2019av在线视频 | av解说在线观看 | 婷婷丁香在线视频 | 免费影视大全推荐 | 午夜精品视频一区 | 久久伦理电影网 | 中文字幕免费一区 | 国产精品一区二区精品视频免费看 | 精品在线免费视频 | 最近日韩中文字幕中文 | 人人射人人射 | 国产在线播放一区二区三区 | 日韩av在线免费播放 | 国产色小视频 | av中文字幕av| 久久大片 | 久久电影中文字幕视频 | 久久精品久久精品 | av在线播放不卡 | 岛国片在线| 免费情趣视频 | 黄色a一级视频 | 2019中文| 日本久久精 | 中文字幕免费久久 | 欧美在线日韩在线 | 国产一级免费观看 | 96精品高清视频在线观看软件特色 | 99视频免费观看 | 精产嫩模国品一二三区 | 欧美性一级观看 | 日韩高清免费在线观看 | 成人久久久久久久久久 | 在线影视 一区 二区 三区 | 国产一级黄色免费看 | 国产片网站| 中文字幕一区二区三区在线观看 | 欧美日韩精品久久久 | 亚洲高清视频在线 | 91在线在线观看 | 香蕉视频日本 | 在线观看av黄色 | 99精品在线| 成人黄色中文字幕 | 久久久精品视频成人 | 国产精品99久久久久久小说 | 操久在线 | 一区免费观看 | 色天天中文 | 久草视频2| 国产精品一区免费观看 | 一本一道波多野毛片中文在线 | 欧美最猛性xxxxx亚洲精品 | av资源在线看| 永久黄网站色视频免费观看w | 开心婷婷色 | 日韩午夜高清 | 免费看的黄色小视频 | 三上悠亚一区二区在线观看 | 韩日电影在线免费看 | 日本在线观看视频一区 | 国产在线小视频 | 涩涩网站在线 | 日韩一区二区三免费高清在线观看 | 97香蕉久久国产在线观看 | 国产精品 国产精品 | 日韩欧美aaa | 精品字幕| 在线免费亚洲 | 激情五月婷婷网 | 亚洲黄色激情小说 | 超碰97免费观看 | 色婷婷视频 | 亚洲影院色 | 亚洲精品毛片一级91精品 | 免费高清在线观看电视网站 | 婷婷色吧| 国产视频在线免费 | av资源网在线播放 | 成人蜜桃视频 | 亚洲欧美日韩不卡 | 欧美福利片在线观看 | 激情五月六月婷婷 | 一本一道波多野毛片中文在线 | 中文字幕在线一区二区三区 | 久久久久久久亚洲精品 | 久久久国产精品一区二区三区 | 精品免费观看视频 | 欧美午夜久久久 | 99性视频 | 日本精品va在线观看 | 亚洲婷婷在线视频 | 亚洲黄色片在线 | 最新色视频 | 亚洲日韩中文字幕 | 亚洲综合射| 91在线视频精品 | 98涩涩国产露脸精品国产网 | 九九免费在线观看视频 | 精品欧美一区二区在线观看 | av福利超碰网站 | 国产最新视频在线观看 | 国产人成精品一区二区三 | 成年人三级网站 | 欧美极品xxxxx | 97超碰中文字幕 | 国产在线国产 | 日本精品视频在线 | 国产福利一区二区在线 | 999免费视频 | 国产中文字幕在线视频 | 911久久香蕉国产线看观看 | 伊甸园av在线 | av福利免费 | 中文字字幕在线 | 日韩黄色在线电影 | 久久免费精品国产 | 色97在线| 激情综合网在线观看 | 高潮久久久久久久久 | 欧美激情第十页 | 国产精品18久久久久久久 | 97色国产| 国产韩国日本高清视频 | 免费日韩三级 | 伊人官网 | 国产伦精品一区二区三区无广告 | 一级黄视频 | 欧美精品少妇xxxxx喷水 | 91激情在线视频 | 亚洲国产午夜精品 | 97精品国产91久久久久久 | 999成人精品 | 99热在线网站 | 成人天堂网 | 在线看黄色的网站 | 欧美成人精品三级在线观看播放 | 婷婷亚洲五月色综合 | 亚洲免费在线播放视频 | 91尤物国产尤物福利在线播放 | 在线免费观看国产黄色 | 国产精品免费久久久久影院仙踪林 | 绯色av一区 | 久精品在线 | 日韩大片在线 | 在线成人一区 | 丁香婷婷色综合亚洲电影 | 日韩欧美视频免费在线观看 | 亚洲成人精品影院 | 午夜精品久久久久久久久久久久久久 | 激情五月婷婷激情 | 岛国精品一区二区 | 国产精品久久久久久a | 免费网站黄 | 人人射 | 亚洲 欧美日韩 国产 中文 | 国产精品免费久久久久影院仙踪林 | 国产一区在线免费观看 | www.亚洲激情.com | 国产视频一区二区三区在线 | 可以免费观看的av片 | 久久这里只有精品首页 | 欧美成人视 | 久久精品视频3 | 一区二区激情视频 | 国内精品久久久久久久久 | zzijzzij亚洲日本少妇熟睡 | 在线精品观看 | 一区二区 久久 | 在线电影 你懂得 | 色婷婷激情电影 | 国产精品精品国产色婷婷 | 国产免费国产 | 四虎在线免费观看视频 | 黄色毛片视频免费 | 久久99深爱久久99精品 | 精品a在线 | 不卡的av中文字幕 | av福利在线导航 | 国产成人av | 中文在线免费看视频 | 久久伦理电影网 | 麻豆一区二区 | 91污污| 黄毛片在线观看 | 欧美影院久久 | 日韩一区二区三区在线观看 | 狠狠狠狠狠狠天天爱 | 久久久久综合精品福利啪啪 | 美女精品 | 美女国产精品 | 久艹在线观看视频 | 国内精品国产三级国产aⅴ久 | av资源免费在线观看 | 国产黄色精品在线观看 | 久久a v视频 | 99视屏| 免费黄色av | 在线va视频 | 久久久亚洲成人 | 久久久久久久久电影 | 四虎影视8848aamm | 99在线热播| 亚洲黄色小说网 | 久久婷婷精品视频 | 国产日韩欧美自拍 | 色综合在 | 日韩一区二区三区视频在线 | 99热在线免费观看 | 色综合久久久久 | 一区二区免费不卡在线 | 日精品 | 中文字幕精品www乱入免费视频 | 999久久国精品免费观看网站 | 日韩在线一级 | 成人高清av在线 | 日本性高潮视频 | 欧美精品国产综合久久 | 亚洲国产人午在线一二区 | 亚洲在线不卡 | av3级在线| 免费看高清毛片 | 在线播放视频一区 | 日韩一区正在播放 | 成人av资源在线 | 人人擦 | 国产精品久久久久久爽爽爽 | 人人澡超碰碰 | 亚洲一区精品二人人爽久久 | 国产在线国偷精品产拍 | 一级黄色电影网站 | 黄色三级免费观看 | 激情欧美丁香 | 久久99精品国产麻豆宅宅 | 最新动作电影 | 97av免费视频 | 视频在线播放国产 | 免费看av在线 | 久久精品视频在线播放 | 精品国产乱码久久久久久1区2匹 | 日韩激情视频在线 | 91成人破解版 | 亚洲精品在线免费观看视频 | 国产美女精品视频 | 久久五月网 | 免费av成人在线 | a级国产乱理论片在线观看 特级毛片在线观看 | 久久综合视频网 | 福利视频网址 | 久久精品久久精品久久精品 | 亚洲一级黄色大片 | 欧美精品国产综合久久 | 亚洲影院天堂 | 免费在线观看av电影 | 丁香免费视频 | 性色av一区二区三区在线观看 | 国产欧美精品一区二区三区 | 国产在线精 | 中文字幕刺激在线 | 欧美日韩国内在线 | 亚洲激情在线播放 | 国产五月婷 | 干亚洲少妇 | 欧美亚洲成人免费 | 国产亚洲精品久久久久秋 | 国产精品国产三级国产不产一地 | 四虎影视精品成人 | 欧美污在线观看 | 亚洲精品色婷婷 | 九九在线视频免费观看 | 中文字幕成人 | 麻豆91网站 | 欧美激情综合色综合啪啪五月 | 亚洲欧美怡红院 | 又爽又黄又无遮挡网站动态图 | 免费福利片| 韩国精品一区二区三区六区色诱 | 麻豆影视网站 | 久久av免费观看 | 伊人成人久久 | 久久久久免费 | 久久成人资源 | 人人爽人人爽人人爽人人爽 | 精品999| 在线国产一区二区 | 日韩一区在线播放 | 久久成人黄色 | 波多野结衣在线观看一区二区三区 | 国产福利在线 | 国产一区二区久久久 | 国产视频高清 | 亚洲无在线 | 亚洲国产精品久久久久久 | 久久久免费毛片 | 欧美动漫一区二区三区 | 色综合激情网 | 看片黄网站 | 91成年人网站 | 又湿又紧又大又爽a视频国产 | 亚洲欧美日韩中文在线 | 成 人 黄 色 免费播放 | 久久亚洲国产精品 | 国产精品久久久久一区二区三区 | 国产96精品 | 亚洲国产999 | 久久国产精品二国产精品中国洋人 | 亚洲国产大片 | 91福利社区在线观看 | 亚洲区另类春色综合小说 | 精品在线观看一区二区 | 成年人免费在线看 | 国产又粗又硬又爽视频 | 国产精品大片免费观看 | 国产成人久久久77777 | 日韩欧美大片免费观看 | 日韩在线视频网 | 亚洲精品黄色在线观看 | 波多野结衣视频一区二区三区 | 精品一二区 | 俺要去色综合狠狠 | 免费av视屏 | 国产成人一级电影 | 日韩av在线免费看 | 午夜久久福利影院 | 国产成人一级 | 国产精品久久久久久久久久久久午夜片 | 国产成人一级 | 久操中文字幕在线观看 | 国产精品久久久久久久久久久久久久 |