日韩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的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产美女精品在线 | 在线视频成人 | 日韩免费高清 | 国产成人综合在线观看 | 久久久久久久久久免费视频 | 日韩精品91偷拍在线观看 | 97福利视频 | 亚洲亚洲精品在线观看 | 欧美黄污视频 | 中文字幕亚洲综合久久五月天色无吗'' | 中文字幕亚洲精品日韩 | 夜夜爱av | 高清不卡免费视频 | 国产99久久久国产精品免费二区 | 天天射一射 | 99r在线精品 | 日韩在线网 | 亚洲欧美日韩国产一区二区 | 91视频久久久久久 | 美女网站一区 | 日韩三级久久 | 在线免费亚洲 | 一区二区三区在线观看中文字幕 | 成人免费视频播放 | 久久毛片高清国产 | 成人在线一区二区三区 | 国产精品麻豆99久久久久久 | 六月天综合网 | www操操操| 天天天天爱天天躁 | 福利网在线 | 亚洲国产黄色片 | 精品99在线 | 一区二区三区三区在线 | 久久一二三四 | 精品视频专区 | 99国产精品久久久久久久久久 | 视频一区二区在线 | 国产成人精品在线观看 | a天堂一码二码专区 | 国产一级在线免费观看 | 伊人色综合久久天天 | 成人精品99 | 国产精品综合久久久久久 | av免费在线网站 | 日日干狠狠操 | 一区二区三区手机在线观看 | zzijzzij亚洲成熟少妇 | 国产高清av在线播放 | 欧美一区二区在线看 | 免费观看91视频大全 | 久章草在线观看 | av黄色免费网站 | 99精品视频免费观看 | 中文字幕在线观看av | 久久久这里有精品 | 久久国产精品电影 | 久久久久久黄色 | 日本精品久久久久中文字幕 | 国内精品久久久久影院一蜜桃 | 免费av视屏 | 天天操天天射天天爱 | 国产精品中文字幕av | 欧美在线1区 | 五月天狠狠操 | 在线精品视频免费观看 | 91久久精品一区二区二区 | 91成人网在线观看 | 国产淫a| 麻豆国产在线播放 | 精品中文字幕在线播放 | 欧美 激情在线 | 久久久精品小视频 | 在线日本v二区不卡 | 精品在线你懂的 | 国产日韩欧美在线免费观看 | 99久久一区 | 免费视频 三区 | 日韩精品在线免费播放 | 欧美日韩破处 | 欧美经典久久 | 精品一二三四在线 | 成人免费91 | 亚洲在线视频观看 | 福利一区二区三区四区 | 玖玖爱国产在线 | 美女视频黄免费的 | 久久精品视频在线观看免费 | 91在线视频播放 | 最新国产精品拍自在线播放 | 国产精品一区二区三区在线免费观看 | 在线视频久 | 五月婷婷激情综合 | 久久久久久久网站 | 日韩精品三区四区 | 日韩免费不卡视频 | 欧美性生交大片免网 | 国产一区二区三区四区大秀 | 在线视频日韩精品 | 国产伦理久久精品久久久久_ | 久久久免费精品视频 | 亚洲精品乱码久久久久久蜜桃欧美 | 国内丰满少妇猛烈精品播放 | 中文字幕在线国产 | 成人av一区二区兰花在线播放 | 色综合中文字幕 | 久久久久在线观看 | 中文字幕在线看 | 五月视频| 国产精品久久久久久久久婷婷 | 91精彩在线视频 | 亚洲伦理精品 | 天堂在线成人 | 精品国产自 | 在线免费黄 | 天天操天天操 | 色婷婷色 | 欧美日韩激情视频8区 | 曰本三级在线 | 久久免费视频4 | 欧美日韩大片在线观看 | 国产 字幕 制服 中文 在线 | 成人小电影在线看 | 久久免费国产精品1 | 国产裸体永久免费视频网站 | www.五月天色| 四虎影视成人永久免费观看亚洲欧美 | 成人动漫视频在线 | 免费看毛片在线 | 精品999在线 | 亚洲日韩中文字幕在线播放 | 国产主播大尺度精品福利免费 | 久久这里有精品 | 久久免费99精品久久久久久 | 国产涩涩在线观看 | 久草精品视频在线播放 | 五月婷婷色 | 精品国产一区二区三区久久 | www.久艹| 精品国产一区二 | 日韩视频免费 | 91中文在线视频 | 少妇高潮流白浆在线观看 | 国产一区麻豆 | 午夜视频一区二区三区 | 五月天婷婷综合 | 日韩av黄 | 国产在线一区观看 | 免费av电影网站 | 91在线在线观看 | 欧美精品久久天天躁 | 亚洲 欧洲 国产 日本 综合 | 久久这里只有精品视频99 | 婷婷.com | 国产品久精国精产拍 | 九九综合久久 | 免费精品| 久草在线高清 | 欧美性极品xxxx做受 | 福利视频一区二区 | 亚洲草视频 | 久久久久久久久久久免费 | 中文字幕精品三级久久久 | 黄色午夜网站 | 99在线精品视频 | 天天添夜夜操 | 在线之家免费在线观看电影 | 婷婷激情在线 | 久久精品综合网 | 色综合天天色综合 | 国产美女精品人人做人人爽 | 波多野结衣动态图 | 3d黄动漫免费看 | 成人免费在线视频观看 | 97国产情侣爱久久免费观看 | 国产在线播放一区二区三区 | 探花视频在线观看+在线播放 | 日韩精品不卡在线 | 日本不卡一区二区 | 精品中文字幕在线 | 久久久久久久久免费 | 日韩精品短视频 | 国产精品av在线免费观看 | 91人人射| 四虎www| 国产精品av在线免费观看 | a级国产毛片 | 日韩一区二区三区高清免费看看 | 日韩va在线观看 | 99在线免费观看 | 久久电影国产免费久久电影 | 国产精品一区二区在线看 | 97超级碰碰碰视频在线观看 | 麻豆视频在线观看免费 | 一区 二区 精品 | 国产婷婷色 | 91亚洲精品久久久久图片蜜桃 | 亚洲波多野结衣 | 久久精品视频99 | 97涩涩视频| 国产韩国精品一区二区三区 | 成人av中文字幕在线观看 | 成人免费电影 | 免费观看一级视频 | 国产精品6999成人免费视频 | 久久激情视频 久久 | 久久久国产精品麻豆 | 成人国产精品免费观看 | 69久久99精品久久久久婷婷 | 又黄又爽免费视频 | 成人免费视频网址 | 色婷婷狠 | 精品久久91 | 中文字幕中文字幕在线中文字幕三区 | 中文av在线播放 | 99视频精品 | 一区二区视频网站 | 日韩精品一区二区免费 | 久久久精品高清 | 毛片永久免费 | 成人cosplay福利网站 | 久久精品视频3 | 国产成人在线播放 | 99精彩视频在线观看免费 | 9ⅰ精品久久久久久久久中文字幕 | 在线成人一区二区 | 狠狠操天天射 | 91视频免费国产 | 91精品黄色 | 99精品国产亚洲 | 91亚洲精品在线 | 91c网站色版视频 | 欧美日韩18 | 日韩理论影院 | 综合色综合 | 狠狠躁夜夜a产精品视频 | 99日精品 | 亚洲免费在线视频 | 天天干天天上 | 免费视频xnxx com | 在线国产黄色 | 精品国产123 | 婷婷色影院 | 天天操狠狠操夜夜操 | 国产手机视频在线观看 | 中文字幕国产一区 | 一区在线播放 | 欧美日韩国产一区二区三区 | 2024国产在线| 久久久久一区二区三区 | 欧美久久精品 | 五月综合 | 成人黄色小视频 | 国产午夜精品一区二区三区嫩草 | 91网址在线看 | 久久精品一级片 | av成人免费在线观看 | 天天干天天操天天射 | 中文字幕日本特黄aa毛片 | 久久视频一区二区 | 91在线精品播放 | 久久99精品国产99久久 | 亚洲国产中文字幕在线视频综合 | av色综合网| 国产精品久久久久久久久久久久 | 日韩高清免费在线观看 | 91av在线免费播放 | 人人玩人人添人人澡超碰 | 天天操天天干天天插 | 国产色女 | 久草| 99久久99| 91av欧美| 亚洲精品中文在线 | 99久精品视频 | 99久热在线精品视频成人一区 | 丁香婷婷在线 | 成人国产一区二区 | 人人澡人人添人人爽一区二区 | 日韩欧美国产激情在线播放 | 中文字幕精品一区二区三区电影 | 极品久久久久久久 | 日日爽天天操 | 天天爱天天草 | 91免费网 | 三级av在线 | 久草网站在线 | 久久草精品 | av福利电影 | 人人狠狠综合久久亚洲婷 | 亚洲欧美在线综合 | 国产免费高清 | 黄色影院在线播放 | 黄网站色视频 | 久久在线免费观看视频 | 在线观看岛国 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 狠狠色狠狠色综合日日92 | 久久在现| 久久精品999| av免费福利| 麻豆va一区二区三区久久浪 | 在线观看黄色的网站 | 亚洲成人免费观看 | 五月天婷婷在线播放 | 久久久免费精品视频 | 久久午夜网 | 国产在线精品福利 | 免费十分钟 | 精品少妇一区二区三区在线 | 日本精品一区二区在线观看 | 一区二区三区www | 91av手机在线观看 | 亚洲成人一二三 | 国产精品久久久久久一二三四五 | 免费看的黄色 | 五月天激情综合 | 激情久久一区二区三区 | 久久激情影院 | 午夜精品福利在线 | 国产精品入口麻豆www | 欧美日韩国产一区二区在线观看 | 亚洲欧美视频网站 | 国产在线视频一区二区 | 久久久久久久久国产 | 91麻豆国产福利在线观看 | 久久亚洲精品国产亚洲老地址 | 国产精品18久久久久vr手机版特色 | 久久精品观看 | 国产黄视频在线观看 | 久草视频在线资源 | 少妇精69xxtheporn | 精品久久网 | 狠狠狠狠狠干 | 日韩精选在线观看 | 国产又粗又长又硬免费视频 | 黄色动态图xx | 日日天天 | 国产成人精品av在线观 | 97电院网手机版 | 久久调教视频 | 国产成人精品久久亚洲高清不卡 | 中文免费在线观看 | 香蕉在线播放 | 中文字幕在线观看一区 | 国产一区视频在线 | 欧美精品一区二区蜜臀亚洲 | 久久99国产精品视频 | 国产精品久久久久久久久久久久久 | 成人少妇影院yyyy | 激情婷婷在线观看 | av888av.com| 日韩精品偷拍 | 久久国产精彩视频 | 久久不见久久见免费影院 | 在线免费中文字幕 | 国产福利精品视频 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 黄色在线观看免费网站 | 五月情婷婷 | 在线观看成人网 | 国产福利精品一区二区 | 欧美日韩精品国产 | 日韩欧美一区二区三区视频 | 日本99干网| 中文字幕乱码亚洲精品一区 | 99精品视频在线观看免费 | 国产成人精品午夜在线播放 | 91成人小视频 | 伊人国产在线播放 | 午夜视频在线瓜伦 | 天天天天天天天操 | 精品一区二区综合 | 黄色高清视频在线观看 | av电影在线观看完整版一区二区 | 色偷偷男人的天堂av | av一级片在线观看 | 久久精品国产一区二区电影 | 日韩中文字幕免费电影 | 成人av高清在线 | 成人免费网站视频 | 成人免费xxx在线观看 | 久久久免费观看视频 | 成人啪啪18免费游戏链接 | 国产成人一区三区 | 久久久久久久久久久免费视频 | 99在线精品视频观看 | 97色综合| 在线成人短视频 | 一区二区三区不卡在线 | 成人黄色在线电影 | 国产在线毛片 | 欧美做受高潮1 | 中文字幕一区在线观看视频 | 天天综合网 天天综合色 | 日韩av黄| 国产高清久久 | 99国产情侣在线播放 | 日韩av高清| 国产高清视频在线免费观看 | 久久综合九色综合97_ 久久久 | 天天干,天天干 | 亚洲日本在线一区 | 久久伦理| 欧美国产日韩在线视频 | 国产在线中文 | 91成人黄色 | 字幕网在线观看 | 欧美日韩久久久 | 国产精品久久久久久超碰 | 国产专区在线 | www.亚洲激情.com | 亚洲精品国偷自产在线99热 | 色婷婷午夜 | 99精品免费网 | 国产视频一区二区三区在线 | 国产视频资源 | 日韩精品一区二区免费 | 国产涩涩在线观看 | 日本精品在线看 | 国产精品网站一区二区三区 | 九九免费在线观看视频 | 日韩网站一区 | 91香蕉视频好色先生 | 四虎影视8848aamm | 亚州欧美精品 | 色在线视频网 | 国产偷国产偷亚洲清高 | 国产区欧美| 久久久久激情电影 | 国产麻豆果冻传媒在线观看 | 韩国av一区二区三区在线观看 | 国产成人在线观看 | 日日操天天射 | 免费毛片一区二区三区久久久 | 亚洲高清不卡av | 黄色亚洲大片免费在线观看 | 日韩高清免费观看 | a级一a一级在线观看 | 免费网站色 | 在线免费中文字幕 | 狠狠躁日日躁夜夜躁av | 天天艹日日干 | 日韩电影一区二区在线观看 | 91日韩在线| 99热在线精品观看 | 亚洲视频电影在线 | www久久久久 | 久操久 | 国产在线中文 | 99在线热播精品免费99热 | 精品欧美一区二区三区久久久 | 久久99久久精品 | 国产精品一区二区av日韩在线 | 国产成人免费av电影 | 久草免费在线视频观看 | 日韩免费观看视频 | 国产一性一爱一乱一交 | av不卡在线看 | 91喷水| 91大神电影 | 射射色| 日韩日韩日韩日韩 | 91成人亚洲| 国产视频在线观看一区 | 久久亚洲免费 | 国产在线看 | 高清有码中文字幕 | 丁香一区二区 | 亚洲成人精品在线 | 永久免费毛片 | 精品在线播放视频 | 成人久久毛片 | 成人黄色小说视频 | 久久综合久久久 | 日韩欧美精品一区 | 日韩av福利在线 | 探花视频在线观看免费版 | 国产免费视频一区二区裸体 | 国产主播大尺度精品福利免费 | 成人精品国产免费网站 | 91中文视频 | 中文在线亚洲 | 国产精品麻豆欧美日韩ww | 日韩免费av网址 | 成 人 黄 色 视频 免费观看 | 精品视频在线免费观看 | 精品一区二区视频 | 天天做天天射 | 国产精品久久久久久久久免费看 | 麻豆mv在线观看 | 四虎影视精品成人 | 狠狠五月天 | 人人澡人人干 | 77国产精品 | 在线观看日本高清mv视频 | 美女精品在线 | 国产九色在线播放九色 | 天天综合视频在线观看 | 最新高清无码专区 | 成片免费观看视频999 | 99久久精品免费一区 | 亚洲综合色婷婷 | 日韩免费一区二区三区 | 少妇高潮冒白浆 | 久久激情小视频 | 成年人免费在线观看网站 | 日本公乱妇视频 | 日韩资源在线 | 日韩av成人在线观看 | 中文字幕在线免费看线人 | 国产亚洲精品久久网站 | 亚洲欧美国产日韩在线观看 | 婷婷丁香视频 | 国内揄拍国产精品 | 不卡av电影在线 | 久久国产午夜精品理论片最新版本 | 久久大片网站 | 丁香av在线 | 91国内在线 | 黄色小视频在线观看免费 | 五月天婷婷在线视频 | 日韩精品久久久久久中文字幕8 | 欧美视频xxx | 亚洲一区精品二人人爽久久 | 色久天| 97人人模人人爽人人少妇 | 久久久久国产视频 | 亚洲理论视频 | 91尤物在线播放 | 日日噜噜噜噜夜夜爽亚洲精品 | 成人黄色在线播放 | 国产中文在线视频 | a视频在线播放 | 日韩欧美成 | 99久久婷婷 | 亚洲少妇xxxx | 亚洲va欧美va人人爽春色影视 | 在线观看av网 | 99精品视频在线播放免费 | 久久看看 | 久久免费久久 | 欧美精品三级在线观看 | 网站免费黄色 | 午夜精品久久久久久久99无限制 | 亚洲一区尤物 | 免费高清在线观看电视网站 | 国产精品一区二区久久久久 | 久久久久成 | 久久在草 | 天天色播 | 欧美精品亚州精品 | 国产精品久久久久久久久久久免费 | 国产精品2020 | 国产美腿白丝袜足在线av | 色偷偷网站视频 | 婷婷丁香社区 | 欧美在线观看视频一区二区 | 久久黄色免费视频 | 欧美性猛片, | 欧美午夜剧场 | 在线影视 一区 二区 三区 | 久久精品香蕉视频 | 午夜电影久久 | 国产精品成人品 | 亚洲成年人免费网站 | 韩日精品在线 | 国产精品免费一区二区 | 综合久久久久久久久 | 成人欧美一区二区三区黑人麻豆 | 欧美一级在线观看视频 | 中文字幕在线字幕中文 | 亚洲精品视频免费看 | 欧美成人一二区 | 伊人婷婷网 | 国产精品久久久久久五月尺 | 国产成人一区二区三区免费看 | 性色av免费看| 久久99电影 | www五月天婷婷 | 免费中文字幕在线观看 | 黄色三级在线看 | 色婷婷www | 超碰97免费在线 | 久久99国产精品久久99 | 国产成人精品日本亚洲999 | 国产视频丨精品|在线观看 国产精品久久久久久久久久久久午夜 | 亚洲美女免费精品视频在线观看 | 欧美久久精品 | 亚洲成人黄色在线 | 一级一片免费看 | 免费毛片一区二区三区久久久 | 久久人人爽人人爽 | 黄色av电影在线观看 | 日韩美在线观看 | 久久久久99999| 精品99久久久久久 | av免费看av | 国产精品久久久777 成人手机在线视频 | 国内综合精品午夜久久资源 | 日韩天堂在线观看 | 日韩高清精品一区二区 | 国内精品免费久久影院 | 亚洲精品视频在线观看免费视频 | 久人人| 青青色影院| 亚洲日本va在线观看 | 免费看黄的 | 97国产精品一区二区 | 狠狠色噜噜狠狠 | av中文字幕在线播放 | 91精品国产自产91精品 | 久久深夜| 五月天天色 | 国产精品久久99精品毛片三a | 高清av免费看 | 337p日本欧洲亚洲大胆裸体艺术 | 2019国产精品| 国产91在线看 | 91av视频在线观看 | 97超碰超碰久久福利超碰 | 日韩视频一区二区三区在线播放免费观看 | 亚洲第一香蕉视频 | 综合精品在线 | 国产精品私人影院 | 人人插人人做 | 亚洲美女免费精品视频在线观看 | 在线观看国产福利片 | 一本色道久久综合亚洲二区三区 | 人人干网 | 婷婷激情5月天 | 狠狠操天天干 | 亚洲黄色免费观看 | 一区二区三区中文字幕在线 | 欧美激情综合五月 | 成人毛片100免费观看 | 亚洲一区二区高潮无套美女 | 精品国产一区二区三区四区vr | 日本中文字幕在线电影 | 五月丁婷婷 | 99综合电影在线视频 | 久久成电影 | 国产自偷自拍 | 久久国产亚洲视频 | 免费av网站在线 | 97中文字幕 | 日韩系列在线 | 日韩av片免费在线观看 | 麻豆视频免费入口 | 免费亚洲电影 | 夜夜夜草 | 蜜臀av夜夜澡人人爽人人桃色 | 成人久久18免费网站麻豆 | 激情网五月天 | 国产麻豆精品免费视频 | 久久国产精品99久久人人澡 | 狠狠操狠狠插 | 九九在线高清精品视频 | 亚洲理论电影 | 91久久黄色 | 精品视频在线免费 | 国产精品美女免费 | 久久艹精品 | 亚洲人人av| 久久久久久久久免费 | 精品成人a区在线观看 | www激情久久 | 天天操夜夜看 | 一级黄色在线视频 | 黄色一级大片免费看 | 久久精品aaa | 一区二区不卡在线观看 | 综合色综合色 | 国产综合香蕉五月婷在线 | 97在线免费视频观看 | 国产日本在线观看 | 在线播放91 | 九九视频精品在线 | 69精品久久 | 91丨九色丨国产丨porny精品 | 国产 亚洲 欧美 在线 | 五月天激情综合 | 最新亚洲视频 | 亚洲干视频在线观看 | 国内精品久久久久久久影视简单 | 在线视频国产区 | 色欧美成人精品a∨在线观看 | 亚洲成人精品久久 | 久操伊人 | 亚州欧美精品 | 国产午夜精品av一区二区 | 天堂av中文字幕 | 欧美精品午夜 | 成人久久视频 | 超碰国产在线播放 | 国产乱老熟视频网88av | 人人爽人人舔 | 丁香在线视频 | 麻豆国产网站入口 | 五月导航 | 美女网站视频久久 | a√天堂中文在线 | 午夜久久影院 | 黄色网中文字幕 | 天天摸日日操 | 视频国产精品 | 九九久久国产 | 中文字幕丝袜 | 亚洲午夜精品久久久久久久久久久久 | 国产美女免费 | 日韩欧美xxx | 激情 一区二区 | 夜夜视频欧洲 | 国产精品一区二区三区观看 | 日韩视频三区 | 友田真希x88av | 综合伊人久久 | 人人澡人摸人人添学生av | 久久久久久久看片 | 在线观看中文字幕dvd播放 | 国产精品久久麻豆 | 国产精品中文 | 久久综合九色综合网站 | 99热在线观看| 亚洲精品国产麻豆 | av解说在线观看 | 五月天亚洲婷婷 | 精品久久久久久久久久岛国gif | 亚洲免费av在线播放 | 色婷婷狠狠五月综合天色拍 | 偷拍视频一区 | 97视频人人免费看 | 国产福利精品一区二区 | www.久久久com | www.色婷婷.com | 黄污在线观看 | 人人爽人人爽人人片av | 久久精品99北条麻妃 | 欧美尹人| 九9热这里真品2 | 成人羞羞视频在线观看免费 | 中文字幕日韩无 | av超碰在线| 国产在线观看二区 | 一本之道乱码区 | 国产精品亚洲片在线播放 | 日韩字幕在线观看 | 99中文视频在线 | 成年人在线观看视频免费 | 精品99999| 91精品国自产在线偷拍蜜桃 | 日韩免费电影网 | 国产中文字幕三区 | 久久免费视频一区 | 亚洲va欧洲va国产va不卡 | 国产精品美女久久久久久 | 国产一级高清 | freejavvideo日本免费 | 精品中文字幕在线播放 | 欧美成人一区二区 | 久久艹人人 | 最近中文字幕 | 91九色蝌蚪视频在线 | 在线www色 | 中文字幕999 | 香蕉在线视频观看 | 日本午夜在线亚洲.国产 | 欧美成人h版在线观看 | 99在线免费视频观看 | 欧美在线观看视频 | 久久免费看av| 性色在线视频 | 成年人网站免费观看 | 欧美性成人 | 国产成人精品999在线观看 | 亚洲午夜精品久久久久久久久久久久 | 午夜精品久久久久久99热明星 | 国产专区免费 | 夜夜狠狠| 99久久国产免费,99久久国产免费大片 | 精品1区二区| 三级黄色网络 | 午夜123 | 中国一级片在线 | 日本激情视频中文字幕 | 国产精品高潮在线观看 | 99这里都是精品 | 成人免费大片黄在线播放 | 一区二区三区国产精品 | 久久精品99国产精品亚洲最刺激 | 在线国产精品视频 | 久久久久久久国产精品影院 | 99精品视频一区二区 | 伊人久久婷婷 | 一区二区三区韩国免费中文网站 | 最近中文字幕免费av | av网站播放| 国产精品久久久影视 | 日韩91av | 色a综合 | 欧美日韩一区二区在线观看 | 国产精品va在线 | 日韩精品一区二区三区在线播放 | 久久99九九99精品 | 性色av免费看 | 337p日本大胆噜噜噜噜 | 欧美一级片在线 | av高清在线观看 | 国产黄色精品在线 | 99精品视频在线播放免费 | 在线观看成人 | 久久不卡国产精品一区二区 | 国产九九九视频 | 亚洲91视频| 久久九九久久九九 | 亚洲精品在线视频网站 | 天天操天天色天天射 | www.99热精品| 免费网站色 | 人人爽人人香蕉 | 国产精品成人品 | 免费观看黄 | 91天堂影院 | 在线高清av | 99性视频 | 成人精品影视 | 国产精品久久久久高潮 | 日韩毛片在线播放 | 97精品国产aⅴ | 丁香婷婷激情国产高清秒播 | 国产又粗又猛又黄视频 | av资源中文字幕 | 免费黄a大片| 日韩中文字幕亚洲一区二区va在线 | 91丨九色丨国产在线观看 | 亚洲专区 国产精品 | 激情婷婷| 69精品在线 | 在线草 | 97超碰免费在线 | 久久精品韩国 | 婷婷丁香七月 | 久久1区 | 久草视频在线新免费 | 韩国一区二区三区在线观看 | 国内精品久久久久久中文字幕 | 亚洲午夜精品久久久 | 精品亚洲一区二区三区 | 亚洲专区一二三 | 黄色tv视频| 久久网站最新地址 | 久久ww | 欧美国产亚洲精品久久久8v | 国产精品久久亚洲 | 国产91精品一区二区绿帽 | 黄色天堂在线观看 | 日韩精品中文字幕av | 免费成人在线网站 | 日本精品视频在线观看 | 中文字幕最新精品 | 国产91免费在线观看 | 免费中文字幕视频 | 免费在线观看日韩欧美 | 日韩有色| 天堂在线免费视频 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 夜夜澡人模人人添人人看 | 日韩欧美xxx | 国产一级片免费播放 | 在线影视 一区 二区 三区 | 久久综合色综合88 | 欧美aaaxxxx做受视频 | 日韩特黄一级欧美毛片特黄 | 久草视频在线资源 | 91在线永久 | 91精品国产九九九久久久亚洲 | 1区2区视频 | 日韩av在线网站 | 日韩精品在线免费播放 | 午夜三级福利 | 麻豆精品传媒视频 | 91视频 - 114av | 国产成人1区| www.狠狠插.com| 美女网站色在线观看 | 国产精品一区二区三区免费看 | 夜夜操天天干 | 天天骚夜夜操 | 久久这里 | 在线亚州| 特黄免费av | 国产麻豆视频在线观看 | 九九热中文字幕 | 91人人干| 国产高清精品在线观看 | 99精品免费观看 | 香蕉在线影院 | 国产精品久久一区二区三区不卡 | 天海翼一区二区三区免费 | 国产精品精品 | a级一a一级在线观看 | 99久久婷婷国产一区二区三区 | 亚洲天堂精品视频 | 欧美一级在线观看视频 | 香蕉视频在线免费看 | 日韩欧美精品一区二区 | 成人免费视频免费观看 | 国产精品日韩 | 免费精品视频 | 久久精品—区二区三区 | 亚洲欧美国产日韩在线观看 | 免费麻豆网站 | 久久av观看| 国产日韩精品一区二区在线观看播放 | 日本乱视频 | 亚洲乱码精品 | 亚洲精品久 | 日韩电影在线观看中文字幕 | 亚洲每日更新 | 在线 精品 国产 | 久久精品在线视频 | 成人动态视频 | 在线观看国产 | 91视频久久久久 | 国产香蕉久久 | 黄色的视频网站 | 亚洲年轻女教师毛茸茸 | 在线观看www.| 日日爽天天 | 揉bbb玩bbb少妇bbb | 日韩欧美亚州 | 色亚洲网| 欧美日韩精品综合 | 亚洲在线视频免费 | 国产麻豆精品久久一二三 | 天天插天天 | 婷婷精品视频 | 国产人成一区二区三区影院 | 色噜噜在线观看视频 | 五月激情站 | 久久国产精品99国产精 | 国产精品麻豆一区二区三区 | 亚洲丝袜一区 | 一区二区三区免费看 | 黄色av影院 | 国产精品免费观看视频 | 日韩另类在线 | 91九色蝌蚪视频网站 | 国产精品久久久电影 | 日韩精品一区在线观看 | 久久国产视频网 | 亚洲 欧美 变态 国产 另类 | 久久66热这里只有精品 | 亚洲国产精品成人av | 99久久日韩精品视频免费在线观看 | 在线观看日本高清mv视频 | 亚洲国产成人在线播放 | 久久一区二区免费视频 | 久久久久美女 | 久久久2o19精品 | 国产亚洲精品福利 | 黄色三级网站 | 精品96久久久久久中文字幕无 | 成 人 黄 色 视频 免费观看 | 成人毛片a | 91av看片 | 人成在线免费视频 | 国产九色91 | 免费av网站在线看 | 操操色 | 最近中文字幕免费av | bbbbb女女女女女bbbbb国产 | 丰满少妇久久久 | 成人午夜黄色影院 | 婷五月天激情 | 日韩精品视频久久 | 天天干天天射天天插 | 亚洲人av免费网站 | 亚洲人在线7777777精品 | 日韩精品一区二区三区在线视频 | 成人午夜影院在线观看 | 国内精品久久久久久 | 三级黄在线 | av一区二区三区在线观看 | 黄色视屏在线免费观看 | 人人爽人人 | 黄色大片日本免费大片 | 片黄色毛片黄色毛片 | 国产无套一区二区三区久久 | 精品久久久久久久久久久久久 | 国内精品视频一区二区三区八戒 | 最新av在线播放 | 国产精品久久久久999 | 在线亚洲精品 | 国产精品高 | 色综合久久88色综合天天 | 国产精品视频免费 | 在线最新av |