亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > PostgreSQL > 正文

PostgreSQL教程(四):數(shù)據(jù)類型詳解

2020-03-12 23:53:26
字體:
供稿:網(wǎng)友
這篇文章主要介紹了PostgreSQL教程(四):數(shù)據(jù)類型詳解,本文講解了數(shù)值類型、字符類型、布爾類型、位串類型、數(shù)組、復(fù)合類型等數(shù)據(jù)類型,需要的朋友可以參考下
 

一、數(shù)值類型:

    下面是PostgreSQL所支持的數(shù)值類型的列表和簡單說明:
PostgreSQL教程(四):數(shù)據(jù)類型詳解

1. 整數(shù)類型:

    類型smallint、integer和bigint存儲各種范圍的全部是數(shù)字的數(shù),也就是沒有小數(shù)部分的數(shù)字。試圖存儲超出范圍以外的數(shù)值將導(dǎo)致一個錯誤。常用的類型是integer,因為它提供了在范圍、存儲空間和性能之間的最佳平衡。一般只有在磁盤空間緊張的時候才使用smallint。而只有在integer的范圍不夠的時候才使用bigint,因為前者(integer)絕對快得多。

    2. 任意精度數(shù)值:

    類型numeric可以存儲最多1000位精度的數(shù)字并且準(zhǔn)確地進行計算。因此非常適合用于貨幣金額和其它要求計算準(zhǔn)確的數(shù)量。不過,numeric類型上的算術(shù)運算比整數(shù)類型或者浮點數(shù)類型要慢很多。
    numeric字段的最大精度和最大比例都是可以配置的。要聲明一個類型為numeric的字段,你可以用下面的語法:
 

復(fù)制代碼代碼如下:

    NUMERIC(precision,scale)
 

    比如數(shù)字23.5141的精度為6,而刻度為4。
    在目前的PostgreSQL版本中,decimal和numeric是等效的。
    
    3. 浮點數(shù)類型:

 

    數(shù)據(jù)類型real和double是不準(zhǔn)確的、犧牲精度的數(shù)字類型。不準(zhǔn)確意味著一些數(shù)值不能準(zhǔn)確地轉(zhuǎn)換成內(nèi)部格式并且是以近似的形式存儲的,因此存儲后再把數(shù)據(jù)打印出來可能顯示一些缺失。
    
   4. Serial(序號)類型:
    serial和bigserial類型不是真正的類型,只是為在表中設(shè)置唯一標(biāo)識做的概念上的便利。
 

復(fù)制代碼代碼如下:

    CREATE TABLE tablename (
        colname SERIAL
    );
 

    等價于
 
復(fù)制代碼代碼如下:

    CREATE SEQUENCE tablename_colname_seq;
    CREATE TABLE tablename(
        colname integer DEFAULT nextval('tablename_colname_seq') NOT NULL
    );
 

    這樣,我們就創(chuàng)建了一個整數(shù)字段并且把它的缺省數(shù)值安排為從一個序列發(fā)生器取值。應(yīng)用了一個NOT NULL約束以確??罩挡粫徊迦搿T诖蠖鄶?shù)情況下你可能還希望附加一個UNIQUE或者PRIMARY KEY約束避免意外地插入重復(fù)的數(shù)值,但這個不是自動發(fā)生的。因此,如果你希望一個序列字段有一個唯一約束或者一個主鍵,那么你現(xiàn)在必須聲明,就像其它數(shù)據(jù)類型一樣。
    還需要另外說明的是,一個serial類型創(chuàng)建的序列在其所屬字段被刪除時,該序列也將被自動刪除,但是其它情況下是不會被刪除的。因此,如果你想用同一個序列發(fā)生器同時給幾個字段提供數(shù)據(jù),那么就應(yīng)該以獨立對象的方式創(chuàng)建該序列發(fā)生器。

 

二、字符類型:

    下面是PostgreSQL所支持的字符類型的列表和簡單說明:

PostgreSQL教程(四):數(shù)據(jù)類型詳解

SQL 定義了兩種基本的字符類型,varchar(n)和char(n),這里的n是一個正整數(shù)。兩種類型都可以存儲最多n個字符長的字串,試圖存儲更長的字串到這些類型的字段里會產(chǎn)生一個錯誤,除非超出長度的字符都是空白,這種情況下該字串將被截斷為最大長度。如果沒有長度聲明,char等于char(1),而varchar則可以接受任何長度的字串。

復(fù)制代碼代碼如下:

    MyTest=> CREATE TABLE testtable(first_col varchar(2));
    CREATE TABLE
    MyTest=> INSERT INTO testtable VALUES('333');   --插入字符串的長度,超過其字段定義的長度,因此報錯。
    ERROR:  value too long for type character varying(2)
    --插入字符串中,超出字段定義長度的部分是空格,因此可以插入,但是空白符被截斷。
    MyTest=> INSERT INTO testtable VALUES('33 ');   
    INSERT 0 1
    MyTest=> SELECT * FROM testtable;
     first_col
    -----------
     33
    (1 row)

    這里需要注意的是,如果是將數(shù)值轉(zhuǎn)換成char(n)或者varchar(n),那么超長的數(shù)值將被截斷成n個字符,而不會拋出錯誤。
復(fù)制代碼代碼如下:

    MyTest=> select 1234::varchar(2);
     varchar
    ---------
     12
    (1 row)

    最后需要提示的是,這三種類型之間沒有性能差別,只不過是在使用char類型時增加了存儲尺寸。雖然在某些其它的數(shù)據(jù)庫系統(tǒng)里,char(n)有一定的性能優(yōu)勢,但在PostgreSQL里沒有。在大多數(shù)情況下,應(yīng)該使用text或者varchar。
    
三、日期/時間類型:

 

    下面是PostgreSQL所支持的日期/時間類型的列表和簡單說明:
PostgreSQL教程(四):數(shù)據(jù)類型詳解

1. 日期/時間輸入:
    任何日期或者時間的文本輸入均需要由單引號包圍,就象一個文本字符串一樣。
    1). 日期:
    以下為合法的日期格式列表:

PostgreSQL教程(四):數(shù)據(jù)類型詳解

2). 時間:
    以下為合法的時間格式列表:

PostgreSQL教程(四):數(shù)據(jù)類型詳解

3). 時間戳:

    時間戳類型的有效輸入由一個日期和時間的聯(lián)接組成,后面跟著一個可選的時區(qū)。因此,1999-01-08 04:05:06和1999-01-08 04:05:06 -8:00都是有效的數(shù)值。
   
   2. 示例:
    1). 在插入數(shù)據(jù)之前先查看datestyle系統(tǒng)變量的值:
 

復(fù)制代碼代碼如下:

    MyTest=> show datestyle;
     DateStyle
    -----------
     ISO, YMD
    (1 row)
 

    2). 創(chuàng)建包含日期、時間和時間戳類型的示例表:
 
復(fù)制代碼代碼如下:

    MyTest=> CREATE TABLE testtable (id integer, date_col date, time_col time, timestamp_col timestamp);
    CREATE TABLE
 

    3). 插入數(shù)據(jù):
 
復(fù)制代碼代碼如下:

    MyTest=> INSERT INTO testtable(id,date_col) VALUES(1, DATE'01/02/03');  --datestyle為YMD
    INSERT 0 1
    MyTest=> SELECT id, date_col FROM testtable;
     id   |  date_col
    ----+------------
      1  | 2001-02-03
    (1 row)
    
    MyTest=> set datestyle = MDY;
    SET
    MyTest=> INSERT INTO testtable(id,date_col) VALUES(2, DATE'01/02/03');  --datestyle為MDY
    INSERT 0 1
    MyTest=> SELECT id,date_col FROM testtable;
     id   |  date_col
    ----+------------
      1  | 2001-02-03
      2  | 2003-01-02 

 

    MyTest=> INSERT INTO testtable(id,time_col) VALUES(3, TIME'10:20:00');  --插入時間。
    INSERT 0 1
    MyTest=> SELECT id,time_col FROM testtable WHERE time_col IS NOT NULL;
     id   | time_col
    ----+----------
      3   | 10:20:00
    (1 row)

    MyTest=> INSERT INTO testtable(id,timestamp_col) VALUES(4, DATE'01/02/03'); 
    INSERT 0 1
    MyTest=> INSERT INTO testtable(id,timestamp_col) VALUES(5, TIMESTAMP'01/02/03 10:20:00');
    INSERT 0 1
    MyTest=> SELECT id,timestamp_col FROM testtable WHERE timestamp_col IS NOT NULL;
     id   |    timestamp_col
    ----+---------------------
      4  | 2003-01-02 00:00:00
      5  | 2003-01-02 10:20:00
    (2 rows)
 

 

四、布爾類型:

    PostgreSQL支持標(biāo)準(zhǔn)的SQL boolean數(shù)據(jù)類型。boolean只能有兩個狀態(tài)之一:真(True)或 假(False)。該類型占用1個字節(jié)。
    "真"值的有效文本值是:
 

復(fù)制代碼代碼如下:

    TRUE
    't'
    'true'
    'y'
    'yes'
    '1'
 

    而對于"假"而言,你可以使用下面這些:
 
復(fù)制代碼代碼如下:

    FALSE
    'f'
    'false'
    'n'
    'no'
    '0'
 

  見如下使用方式:
復(fù)制代碼代碼如下:

    MyTest=> CREATE TABLE testtable (a boolean, b text);
    CREATE TABLE
    MyTest=> INSERT INTO testtable VALUES(TRUE, 'sic est');
    INSERT 0 1
    MyTest=> INSERT INTO testtable VALUES(FALSE, 'non est');
    INSERT 0 1
    MyTest=> SELECT * FROM testtable;
     a  |    b
    ---+---------
     t  | sic est
     f  | non est
    (2 rows)    
    MyTest=> SELECT * FROM testtable WHERE a;
     a  |    b
    ---+---------
     t  | sic est
    (1 row)    
    MyTest=> SELECT * FROM testtable WHERE a = true;
     a  |    b
    ---+---------
     t  | sic est
    (1 row)
 
   
五、位串類型:

 

    位串就是一串1和0的字串。它們可以用于存儲和視覺化位掩碼。我們有兩種類型的SQL位類型:bit(n)和bit varying(n); 這里的n是一個正整數(shù)。bit類型的數(shù)據(jù)必須準(zhǔn)確匹配長度n; 試圖存儲短些或者長一些的數(shù)據(jù)都是錯誤的。類型bit varying數(shù)據(jù)是最長n的變長類型;更長的串會被拒絕。寫一個沒有長度的bit等效于bit(1),沒有長度的bit varying相當(dāng)于沒有長度限制。
    針對該類型,最后需要提醒的是,如果我們明確地把一個位串值轉(zhuǎn)換成bit(n),那么它的右邊將被截斷或者在右邊補齊零,直到剛好n位,而不會拋出任何錯誤。類似地,如果我們明確地把一個位串?dāng)?shù)值轉(zhuǎn)換成bit varying(n),如果它超過n位,那么它的右邊將被截斷。 見如下具體使用方式:    
 

復(fù)制代碼代碼如下:

    MyTest=> CREATE TABLE testtable (a bit(3), b bit varying(5));
    CREATE TABLE
    MyTest=> INSERT INTO testtable VALUES (B'101', B'00');
    INSERT 0 1
    MyTest=> INSERT INTO testtable VALUES (B'10', B'101');
    ERROR:  bit string length 2 does not match type bit(3)
    MyTest=> INSERT INTO testtable VALUES (B'10'::bit(3), B'101');
    INSERT 0 1
    MyTest=> SELECT * FROM testtable;
      a  |  b
    -----+-----
     101 | 00
     100 | 101
    (2 rows)
    MyTest=> SELECT B'11'::bit(3);
     bit
    -----
     110
    (1 row)

 

 

 

六、數(shù)組:

    1. 數(shù)組類型聲明:
    1). 創(chuàng)建字段含有數(shù)組類型的表。
 

復(fù)制代碼代碼如下:

    CREATE TABLE sal_emp (
        name            text,
        pay_by_quarter  integer[] --還可以定義為integer[4]或integer ARRAY[4]
    );
 

    2). 插入數(shù)組數(shù)據(jù):
 
復(fù)制代碼代碼如下:

    MyTest=# INSERT INTO sal_emp VALUES ('Bill', '{11000, 12000, 13000, 14000}');
    INSERT 0 1
    MyTest=# INSERT INTO sal_emp VALUES ('Carol', ARRAY[21000, 22000, 23000, 24000]);
    INSERT 0 1
    MyTest=# SELECT * FROM sal_emp;
     name  |      pay_by_quarter
    --------+---------------------------
     Bill     | {11000,12000,13000,14000}
     Carol  | {21000,22000,23000,24000}
    (2 rows)    

    2. 訪問數(shù)組:
    和其他語言一樣,PostgreSQL中數(shù)組也是通過下標(biāo)數(shù)字(寫在方括弧內(nèi))的方式進行訪問,只是PostgreSQL中數(shù)組元素的下標(biāo)是從1開始n結(jié)束。
 
復(fù)制代碼代碼如下:

    MyTest=# SELECT pay_by_quarter[3] FROM sal_emp;
     pay_by_quarter
    ----------------
              13000
              23000
    (2 rows)
    MyTest=# SELECT name FROM sal_emp WHERE pay_by_quarter[1] <> pay_by_quarter[2];
     name
    ------
     Bill
     Carol
    (2 rows)
 

    PostgreSQL中還提供了訪問數(shù)組范圍的功能,即ARRAY[腳標(biāo)下界:腳標(biāo)上界]。
 
復(fù)制代碼代碼如下:

    MyTest=# SELECT name,pay_by_quarter[1:3] FROM sal_emp;
     name  |   pay_by_quarter
    --------+---------------------
     Bill     | {11000,12000,13000}
     Carol  | {21000,22000,23000}
    (2 rows)
   

    3. 修改數(shù)組:
    1). 代替全部數(shù)組值:
 
復(fù)制代碼代碼如下:

    --UPDATE sal_emp SET pay_by_quarter = ARRAY[25000,25000,27000,27000] WHERE name = 'Carol'; 也可以。
    MyTest=# UPDATE sal_emp SET pay_by_quarter = '{31000,32000,33000,34000}' WHERE name = 'Carol';
    UPDATE 1
    MyTest=# SELECT * FROM sal_emp;
     name  |      pay_by_quarter
    --------+---------------------------
     Bill     | {11000,12000,13000,14000}
     Carol  | {31000,32000,33000,34000}
    (2 rows)
 

    2). 更新數(shù)組中某一元素:
 
復(fù)制代碼代碼如下:

    MyTest=# UPDATE sal_emp SET pay_by_quarter[4] = 15000 WHERE name = 'Bill';
    UPDATE 1
    MyTest=# SELECT * FROM sal_emp;
     name  |      pay_by_quarter
    --------+---------------------------
     Carol  | {31000,32000,33000,34000}
     Bill     | {11000,12000,13000,15000}
    (2 rows)
 

    3). 更新數(shù)組某一范圍的元素:
 
復(fù)制代碼代碼如下:

    MyTest=# UPDATE sal_emp SET pay_by_quarter[1:2] = '{37000,37000}' WHERE name = 'Carol';
    UPDATE 1
    MyTest=# SELECT * FROM sal_emp;
     name  |      pay_by_quarter
    --------+---------------------------
     Bill     | {11000,12000,13000,15000}
     Carol  | {37000,37000,33000,34000}
    (2 rows)
 

    4). 直接賦值擴大數(shù)組:
 
復(fù)制代碼代碼如下:

    MyTest=# UPDATE sal_emp SET pay_by_quarter[5] = 45000 WHERE name = 'Bill';
    UPDATE 1
    MyTest=# SELECT * FROM sal_emp;
     name  |         pay_by_quarter
    --------+---------------------------------
     Carol  | {37000,37000,33000,34000}
     Bill     | {11000,12000,13000,15000,45000}
    (2 rows)

    4. 在數(shù)組中檢索:
    1). 最簡單直接的方法:
 
復(fù)制代碼代碼如下:

    SELECT * FROM sal_emp WHERE pay_by_quarter[1] = 10000 OR
                            pay_by_quarter[2] = 10000 OR
                            pay_by_quarter[3] = 10000 OR
                            pay_by_quarter[4] = 10000;    

    2). 更加有效的方法:
 
復(fù)制代碼代碼如下:

    SELECT * FROM sal_emp WHERE 10000 = ANY (pay_by_quarter); --數(shù)組元素中有任何一個等于10000,where條件將成立。
    SELECT * FROM sal_emp WHERE 10000 = ALL (pay_by_quarter); --只有當(dāng)數(shù)組中所有的元素都等于10000時,where條件才成立。

 

七、復(fù)合類型:

    PostgreSQL中復(fù)合類型有些類似于C語言中的結(jié)構(gòu)體,也可以被視為Oracle中的記錄類型,但是還是感覺復(fù)合類型這個命名比較貼切。它實際上只是一個字段名和它們的數(shù)據(jù)類型的列表。PostgreSQL允許像簡單數(shù)據(jù)類型那樣使用復(fù)合類型。比如,表字段可以聲明為一個復(fù)合類型。

    1. 聲明復(fù)合類型:

    下面是兩個簡單的聲明示例:
 

復(fù)制代碼代碼如下:

    CREATE TYPE complex AS (
        r double,
        i double
    );   
    CREATE TYPE inventory_item AS (
        name           text,
        supplier_id   integer,
        price            numeric
    );
 

    和聲明一個數(shù)據(jù)表相比,聲明類型時需要加AS關(guān)鍵字,同時在聲明TYPE時不能定義任何約束。下面我們看一下如何在表中指定復(fù)合類型的字段,如:
 
復(fù)制代碼代碼如下:

    CREATE TABLE on_hand (
        item      inventory_item,
        count    integer
    );
 

    最后需要指出的是,在創(chuàng)建表的時候,PostgreSQL也會自動創(chuàng)建一個與該表對應(yīng)的復(fù)合類型,名字與表字相同,即表示該表的復(fù)合類型。
    
    2. 復(fù)合類型值輸入:
    我們可以使用文本常量的方式表示復(fù)合類型值,即在圓括號里包圍字段值并且用逗號分隔它們。你也可以將任何字段值用雙引號括起,如果值本身包含逗號或者圓括號,那么就用雙引號括起,對于上面的inventory_item復(fù)合類型的輸入如下:
 
復(fù)制代碼代碼如下:

    '("fuzzy dice",42,1.99)'
 

    如果希望類型中的某個字段為NULL,只需在其對應(yīng)的位置不予輸入即可,如下面的輸入中price字段的值為NULL,
 
復(fù)制代碼代碼如下:

    '("fuzzy dice",42,)'
 

    如果只是需要一個空字串,而非NULL,寫一對雙引號,如:
 
復(fù)制代碼代碼如下:

    '("",42,)'
 

    在更多的場合中PostgreSQL推薦使用ROW表達式來構(gòu)建復(fù)合類型值,使用該種方式相對簡單,無需考慮更多標(biāo)識字符問題,如:
 
復(fù)制代碼代碼如下:

    ROW('fuzzy dice', 42, 1.99)
    ROW('', 42, NULL)
 

    注:對于ROW表達式,如果里面的字段數(shù)量超過1個,那么關(guān)鍵字ROW就可以省略,因此以上形式可以簡化為:
 
復(fù)制代碼代碼如下:

    ('fuzzy dice', 42, 1.99)
    ('', 42, NULL)
   

    3. 訪問復(fù)合類型:
    訪問復(fù)合類型中的字段和訪問數(shù)據(jù)表中的字段在形式上極為相似,只是為了對二者加以區(qū)分,PostgreSQL設(shè)定在訪問復(fù)合類型中的字段時,類型部分需要用圓括號括起,以避免混淆,如:
 
復(fù)制代碼代碼如下:

    SELECT (item).name FROM on_hand WHERE (item).price > 9.99;
 

    如果在查詢中也需要用到表名,那么表名和類型名都需要被圓括號括起,如:
 
復(fù)制代碼代碼如下:

    SELECT (on_hand.item).name FROM on_hand WHERE (on_hand.item).price > 9.99;
   

    4. 修改復(fù)合類型:
    見如下幾個示例:
 
復(fù)制代碼代碼如下:

    --直接插入復(fù)合類型的數(shù)據(jù),這里是通過ROW表達式來完成的。
    INSERT INTO on_hand(item) VALUES(ROW("fuzzy dice",42,1.99));
    --在更新操作中,也是可以通過ROW表達式來完成。
    UPDATE on_hand SET item = ROW("fuzzy dice",42,1.99) WHERE count = 0;
    --在更新復(fù)合類型中的一個字段時,我們不能在SET后面出現(xiàn)的字段名周圍加圓括號,
    --但是在等號右邊的表達式里引用同一個字段時卻需要圓括號。
    UPDATE on_hand SET item.price = (item).price + 1 WHERE count = 0;
    --可以在插入中,直接插入復(fù)合類型中字段。
    INSERT INTO on_hand (item.supplier_id, item.price) VALUES(100, 2.2);
 

 

    該篇博客是對PostgreSQL官方文檔中“數(shù)據(jù)類型”章節(jié)的簡單歸納,這里之所以用一篇獨立的博客來專門介紹,不僅是為了系統(tǒng)學(xué)習(xí),也便于今后需要時的快速查閱。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
成人性免费视频| 午夜精品一区二区三区在线观看| 97成人在线观看| www.国产一区| 在线看片国产福利你懂的| 国产精品91久久| 视频一区在线观看| 国产精品久久久久久久av电影| 成人精品视频一区二区| 又大又硬又爽免费视频| 日本精品在线一区| 91丨porny丨在线| 中文字幕国内自拍| 天天射综合网站| 姬川优奈aav一区二区| 免费日韩av片| 欧美图片一区二区| 久久亚洲精品中文字幕冲田杏梨| 日本一本久久| 精品一区二区91| www.com亚洲| 精品动漫3d一区二区三区免费| 亚洲制服中文| 国产小视频精品| 一区二区精品在线| 亚洲乱码中文字幕综合| 超碰免费在线观看| 欧美精品久久久久久久免费| 最好看的2019年中文视频| 欧美美女搞黄| 久久国产精品电影| 亚洲精品色午夜无码专区日韩| 在线一区二区三区四区五区| 国产精品人人妻人人爽| 国产精品视频一区二区三区四区五区| 波多野结衣黄色网址| 精品精品国产高清一毛片一天堂| fc2ppv国产精品久久| 岛国av一区二区在线在线观看| 中文字幕久精品免费视频| 亚洲**毛片| 成人免费视频网站在线看| 日韩美女精品在线| 日韩av在线天堂网| 忘忧草在线日韩www影院| 狠狠色狠狠色综合日日五| 日韩亚洲欧美精品| 国产精品一国产精品最新章节| 色综合天天做天天爱| 啊啊啊啊啊啊啊视频在线播放| 欧美一区二区三区在线免费观看| 在线能看的av网站| 国产专区第一页| 91精品久久久久久久久久| 五月天综合激情网| 欧洲亚洲视频| av日韩在线免费观看| 日韩视频一二区| 国产综合网站| 久久亚洲国产成人精品无码区| 中文字幕一区二区三区不卡在线| 久久精品国内一区二区三区水蜜桃| 国产日本在线| 国产裸体免费无遮挡| 免费一级特黄录像| 国产精品久久久久久久久男| 成人国产精品视频| 特黄特色特刺激视频免费播放| 国产精品国产福利国产秒拍| 538在线视频观看| 黄网视频午夜青春| 日韩视频第二页| 久久精品无码一区二区三区毛片| jizz免费一区二区三区| 亚洲网站在线看| 亚洲一本二本| 国产成人一区二区三区| 中日韩在线观看视频| 色先锋资源久久综合5566| 国产成人av电影在线| 一区二区三区四区视频免费观看| 国产三级久久久| 好吊色一区二区三区| 亚洲激情视频一区| 国产亚洲精品美女久久久m| 日日干夜夜操| www.狠狠艹| 精品欧美一区二区久久久| 伦理中文字幕亚洲| 久久9999免费视频| 色佬视频在线观看| 精品综合久久久久久8888| av一区二区三区黑人| 99热这里只有精品66| h网站免费观看| 亚洲成色777777在线观看影院| 国产www.大片在线| 最好看的日本字幕mv视频大全| 男人的天堂导航| 中文字幕视频网站| 日韩一级免费视频| 天堂资源在线播放| 337p亚洲精品色噜噜狠狠| 国产露脸无套对白在线播放| 欧美亚洲高清一区二区三区不卡| 欧美情侣在线播放| 亚洲18在线| 青青草原在线免费观看| 久久精品国产大片免费观看| 黄色成年人视频在线观看| 成人av在线一区二区| 国产九九在线观看| 黄色av网站免费观看| 日韩经典中文字幕| 伊人网站在线观看| 人妻妺妺窝人体色www聚色窝| 一级片avav网址| 一区二区三区四区电影| 欧美日本视频一区| 欧美高清性xxxxhdvideosex| 免费在线观看毛片网站| 欧美亚洲人成在线| 亚洲综合婷婷| 国产伦精品一区二区三区四区免费| 欧美日韩伦理一区二区| 日韩亚洲色图| 国产精品一二三区在线观看| 91精品国产高清一区二区三密臀| 国产成人免费91av在线| 麻豆传媒免费在线观看| 欧美色图在线观看| 青青青在线免费观看| 免费亚洲一区| 国产精品嫩草影院久久久| 国产精品日韩三级| 三级网站在线看| 天天干,天天干| 最近中文字幕mv2018在线高清| 96sao精品免费视频观看| 在线观看91久久久久久| 日本公妇乱淫免费视频一区三区| 三上悠亚久久精品| 欧美一区2区视频在线观看| 伦理一区二区| 性爱在线免费视频| 隣の若妻さん波多野结衣| 日韩亚洲精品电影| 欧洲视频一区二区| 久久久久久久久久久福利| 亚洲精品不卡| 亚洲日本香蕉视频| 亚洲一级Av无码毛片久久精品| 福利视频第一区| 欧美一区二区在线免费观看| 成人一级片在线观看| 99精品在线观看视频| 日韩理论片中文av| 欧美极品在线观看| 亚洲欧美日韩国产yyy| 欧美日韩伦理一区二区| 国产精品333| 日韩国产一区三区| 麻豆明星ai换脸视频| av成人黄色| 国产亚洲精品成人| 天堂а√在线中文在线鲁大师| 欧美性生活影院| 欧美成人手机在线| 制服丝袜日韩国产| 国产精品12| 日韩国产在线一| 久久久久久国产精品免费无遮挡| 国产亚洲精品午夜高清影院| 国产夫妻性爱视频| 中国 免费 av| 黄网址在线永久免费观看| 韩国美女久久| 91九色综合久久| p色视频免费在线观看| 欧美日韩在线精品一区二区三区激情| www.91在线播放| 免费精品国产自产拍在| 99精品欧美一区二区三区| 日本一区二区三区在线免费观看| 精品免费国产一区二区三区四区| 成黄免费在线| 欧美日韩在线精品一区二区三区| 欧美男同视频网| 精品国产美女福利到在线不卡| 2023国产在线观看| 亚洲国产图片| av资源种子在线观看| 麻豆91在线| 国产aaa一级片| 天堂中文在线观看| 国产精品久久综合av爱欲tv| 国产在线观看色| 热门国产精品亚洲第一区在线| 亚洲区自拍偷拍| 黄色在线网站| 亚洲一区二区自偷自拍| 爱豆国产剧免费观看大全剧苏畅| 久久精品亚洲一区| 老司机福利在线视频| 免费**毛片在线| 亚洲影视在线播放| 亚洲精品ady| 久久亚洲专区| av午夜精品一区二区三区| 97久久综合精品久久久综合| 高潮一区二区| 国产大奶在线| 日本乱码高清不卡字幕| 亚洲第一色视频| 肉色超薄丝袜脚交| 久久成人一区二区| 精品国产乱码一区二区三区| 三级无遮挡在线观看| 精品国产乱码一区二区三区四区| 三级欧美韩日大片在线看| 人妻精品无码一区二区三区| 男女爱爱视频免费| 亚洲国产视频二区| 粉嫩一区二区三区四区公司1| 狠狠鲁狠狠操| 亚洲伊人伊色伊影伊综合网| 超级碰碰不卡在线视频| 天天色天天综合网| 日韩一区二区三区电影在线观看| 久久免费在线观看| 午夜性色福利影院| 性欧美videohd高精| av成人在线播放| 色www精品视频在线观看| 涩爱av色老久久精品偷偷鲁| 久久综合色综合| 成人综合婷婷国产精品久久| 日本在线成人一区二区| 久久精品国内一区二区三区水蜜桃| 日韩精品在线观看网站| 欧美一级视频免费观看| 97伦理在线四区| 一本大道久久a久久精品| 色久欧美在线视频观看| 欧美孕妇与黑人巨交| 亚洲第一视频网站| 国产精品成av人在线视午夜片| 国产一级久久久| 中文字幕免费视频| 日韩有码中文字幕在线| 国产在线激情视频| 国产精品久久久久高潮| 午夜精品福利一区二区三区av| 欧美怡春院一区二区三区| 国产极品jizzhd欧美| 青青草一区二区| 99国内精品久久久久久久软件| 国产精品免费看片| 青青操视频在线观看| 中文字幕日产av一二三区| 精品国产亚洲AV| 亚洲国产精品中文| 国产一区精品二区| 日韩午夜激情电影| freexxx性亚洲精品| 5g国产欧美日韩视频| 亚洲一区二区三区四区在线| www.亚洲色图| 99久久亚洲| 揄拍成人国产精品视频| 最新国产精品| 最新版天堂中文在线官网| 捆绑调教日本一区二区三区| 欧美高清视频手机在在线| 韩国女同性做爰三级| 国产麻豆一区二区三区精品视频| 中文字幕一区三区久久女搜查官| 人妻少妇精品一区二区三区| 九色porny丨精品自拍视频| 国产福利在线观看| 无码人妻丰满熟妇区毛片蜜桃精品| 依人在线免费视频| 丁香花电影在线观看完整版| 国产在线视频精品视频免费看| 好色先生视频污| 欧美国产精品一区| 久久综合色天天久久综合图片| 奇米影音第四色| 午夜影院在线观看国产主播| 亚洲精品一区二区在线看| 翔田千里一区二区| 996这里只有精品| www.久久久久久| 精品麻豆剧传媒av国产九九九| 91在线观看高清| 国产农村av| 黑人与娇小精品av专区| 久久免费视频在线| 日韩一本精品| 国产精品久久久久久久裸模| 91网在线看| 日韩一级片在线免费观看| 亚洲精品国产综合久久| 精品一区毛片| 亚洲国产一区二区在线观看| 免费成人深夜夜行网站视频| 狠狠色一日本高清视频| 久久久久亚洲av成人片| 日韩精品一区二区三区免费观看| av网站中文字幕| 久久久久久无码精品人妻一区二区| 日韩的一区二区| 亚洲高清视频免费观看| av成人天堂| 黄色成年人视频在线观看| 精选一区二区三区四区五区| 成年人网站免费观看| 色噜噜狠狠一区二区三区狼国成人| 亚洲欧美日本一区二区三区| 久久久综合久久| 亚洲精品一区二区三区蜜桃久| 欧美日韩一区二区在线观看视频| 亚洲二区在线播放视频| 91美女主播在线视频| 桃乃木香奈和黑人aⅴ在线播放| 国内精品久久久久影院优| 亚洲美女免费视频| av高清一区|