国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

oracle 存儲(chǔ)過(guò)程詳細(xì)介紹(創(chuàng)建,刪除存儲(chǔ)過(guò)程,參數(shù)傳遞等)

 更新時(shí)間:2014年06月01日 00:38:40   作者:  
這篇文章主要介紹了oracle 創(chuàng)建,刪除存儲(chǔ)過(guò)程,參數(shù)傳遞,創(chuàng)建,刪除存儲(chǔ)函數(shù),存儲(chǔ)過(guò)程和函數(shù)的查看,包,系統(tǒng)包等相關(guān)資料,需要的朋友可以參考下

oracle 創(chuàng)建,刪除存儲(chǔ)過(guò)程,參數(shù)傳遞,創(chuàng)建,刪除存儲(chǔ)函數(shù),存儲(chǔ)過(guò)程和函數(shù)的查看,包,系統(tǒng)包

認(rèn)識(shí)存儲(chǔ)過(guò)程和函數(shù)

存儲(chǔ)過(guò)程和函數(shù)也是一種PL/SQL塊,是存入數(shù)據(jù)庫(kù)的PL/SQL塊。但存儲(chǔ)過(guò)程和函數(shù)不同于已經(jīng)介紹過(guò)的PL/SQL程序,我們通常把PL/SQL程序稱為無(wú)名塊,而存儲(chǔ)過(guò)程和函數(shù)是以命名的方式存儲(chǔ)于數(shù)據(jù)庫(kù)中的。和PL/SQL程序相比,存儲(chǔ)過(guò)程有很多優(yōu)點(diǎn),具體歸納如下:
* 存儲(chǔ)過(guò)程和函數(shù)以命名的數(shù)據(jù)庫(kù)對(duì)象形式存儲(chǔ)于數(shù)據(jù)庫(kù)當(dāng)中。存儲(chǔ)在數(shù)據(jù)庫(kù)中的優(yōu)點(diǎn)是很明顯的,因?yàn)榇a不保存在本地,用戶可以在任何客戶機(jī)上登錄到數(shù)據(jù)庫(kù),并調(diào)用或修改代碼。
* 存儲(chǔ)過(guò)程和函數(shù)可由數(shù)據(jù)庫(kù)提供安全保證,要想使用存儲(chǔ)過(guò)程和函數(shù),需要有存儲(chǔ)過(guò)程和函數(shù)的所有者的授權(quán),只有被授權(quán)的用戶或創(chuàng)建者本身才能執(zhí)行存儲(chǔ)過(guò)程或調(diào)用函數(shù)。
* 存儲(chǔ)過(guò)程和函數(shù)的信息是寫入數(shù)據(jù)字典的,所以存儲(chǔ)過(guò)程可以看作是一個(gè)公用模塊,用戶編寫的PL/SQL程序或其他存儲(chǔ)過(guò)程都可以調(diào)用它(但存儲(chǔ)過(guò)程和函數(shù)不能調(diào)用PL/SQL程序)。一個(gè)重復(fù)使用的功能,可以設(shè)計(jì)成為存儲(chǔ)過(guò)程,比如:顯示一張工資統(tǒng)計(jì)表,可以設(shè)計(jì)成為存儲(chǔ)過(guò)程;一個(gè)經(jīng)常調(diào)用的計(jì)算,可以設(shè)計(jì)成為存儲(chǔ)函數(shù);根據(jù)雇員編號(hào)返回雇員的姓名,可以設(shè)計(jì)成存儲(chǔ)函數(shù)。
* 像其他高級(jí)語(yǔ)言的過(guò)程和函數(shù)一樣,可以傳遞參數(shù)給存儲(chǔ)過(guò)程或函數(shù),參數(shù)的傳遞也有多種方式。存儲(chǔ)過(guò)程可以有返回值,也可以沒(méi)有返回值,存儲(chǔ)過(guò)程的返回值必須通過(guò)參數(shù)帶回;函數(shù)有一定的數(shù)據(jù)類型,像其他的標(biāo)準(zhǔn)函數(shù)一樣,我們可以通過(guò)對(duì)函數(shù)名的調(diào)用返回函數(shù)值。
   存儲(chǔ)過(guò)程和函數(shù)需要進(jìn)行編譯,以排除語(yǔ)法錯(cuò)誤,只有編譯通過(guò)才能調(diào)用。

創(chuàng)建和刪除存儲(chǔ)過(guò)程

創(chuàng)建存儲(chǔ)過(guò)程,需要有CREATE PROCEDURE或CREATE ANY PROCEDURE的系統(tǒng)權(quán)限。該權(quán)限可由系統(tǒng)管理員授予。創(chuàng)建一個(gè)存儲(chǔ)過(guò)程的基本語(yǔ)句如下:
CREATE [OR REPLACE] PROCEDURE 存儲(chǔ)過(guò)程名[(參數(shù)[IN|OUT|IN OUT] 數(shù)據(jù)類型...)]
{AS|IS}
[說(shuō)明部分]
BEGIN
可執(zhí)行部分
[EXCEPTION
錯(cuò)誤處理部分]
END [過(guò)程名];

其中:
可選關(guān)鍵字OR REPLACE 表示如果存儲(chǔ)過(guò)程已經(jīng)存在,則用新的存儲(chǔ)過(guò)程覆蓋,通常用于存儲(chǔ)過(guò)程的重建。
參數(shù)部分用于定義多個(gè)參數(shù)(如果沒(méi)有參數(shù),就可以省略)。參數(shù)有三種形式:IN、OUT和IN OUT。如果沒(méi)有指明參數(shù)的形式,則默認(rèn)為IN。
關(guān)鍵字AS也可以寫成IS,后跟過(guò)程的說(shuō)明部分,可以在此定義過(guò)程的局部變量。
編寫存儲(chǔ)過(guò)程可以使用任何文本編輯器或直接在SQL*Plus環(huán)境下進(jìn)行,編寫好的存儲(chǔ)過(guò)程必須要在SQL*Plus環(huán)境下進(jìn)行編譯,生成編譯代碼,原代碼和編譯代碼在編譯過(guò)程中都會(huì)被存入數(shù)據(jù)庫(kù)。編譯成功的存儲(chǔ)過(guò)程就可以在Oracle環(huán)境下進(jìn)行調(diào)用了。
一個(gè)存儲(chǔ)過(guò)程在不需要時(shí)可以刪除。刪除存儲(chǔ)過(guò)程的人是過(guò)程的創(chuàng)建者或者擁有DROP ANY PROCEDURE系統(tǒng)權(quán)限的人。刪除存儲(chǔ)過(guò)程的語(yǔ)法如下:

DROP PROCEDURE 存儲(chǔ)過(guò)程名;

如果要重新編譯一個(gè)存儲(chǔ)過(guò)程,則只能是過(guò)程的創(chuàng)建者或者擁有ALTER ANY PROCEDURE系統(tǒng)權(quán)限的人。語(yǔ)法如下:

ALTER PROCEDURE 存儲(chǔ)過(guò)程名 COMPILE;

執(zhí)行(或調(diào)用)存儲(chǔ)過(guò)程的人是過(guò)程的創(chuàng)建者或是擁有EXECUTE ANY PROCEDURE系統(tǒng)權(quán)限的人或是被擁有者授予EXECUTE權(quán)限的人。執(zhí)行的方法如下:
方法1:
EXECUTE 模式名.存儲(chǔ)過(guò)程名[(參數(shù)...)];
方法2:
BEGIN
模式名.存儲(chǔ)過(guò)程名[(參數(shù)...)];
END;
傳遞的參數(shù)必須與定義的參數(shù)類型、個(gè)數(shù)和順序一致(如果參數(shù)定義了默認(rèn)值,則調(diào)用時(shí)可以省略參數(shù))。參數(shù)可以是變量、常量或表達(dá)式,用法參見(jiàn)下一節(jié)。
如果是調(diào)用本賬戶下的存儲(chǔ)過(guò)程,則模式名可以省略。要調(diào)用其他賬戶編寫的存儲(chǔ)過(guò)程,則模式名必須要添加。
以下是一個(gè)生成和調(diào)用簡(jiǎn)單存儲(chǔ)過(guò)程的訓(xùn)練。注意要事先授予創(chuàng)建存儲(chǔ)過(guò)程的權(quán)限。

【訓(xùn)練1】  創(chuàng)建一個(gè)顯示雇員總?cè)藬?shù)的存儲(chǔ)過(guò)程。

步驟1:登錄SCOTT賬戶(或?qū)W生個(gè)人賬戶)。
步驟2:在SQL*Plus輸入?yún)^(qū)中,輸入以下存儲(chǔ)過(guò)程:

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

CREATE OR REPLACE PROCEDURE EMP_COUNT
AS
V_TOTAL NUMBER(10);
BEGIN
 SELECT COUNT(*) INTO V_TOTAL FROM EMP;
 DBMS_OUTPUT.PUT_LINE('雇員總?cè)藬?shù)為:'||V_TOTAL);
END;

步驟3:按“執(zhí)行”按鈕進(jìn)行編譯。
如果存在錯(cuò)誤,就會(huì)顯示:
警告: 創(chuàng)建的過(guò)程帶有編譯錯(cuò)誤。
如果存在錯(cuò)誤,對(duì)腳本進(jìn)行修改,直到?jīng)]有錯(cuò)誤產(chǎn)生。
如果編譯結(jié)果正確,將顯示:

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

過(guò)程已創(chuàng)建。

步驟4:調(diào)用存儲(chǔ)過(guò)程,在輸入?yún)^(qū)中輸入以下語(yǔ)句并執(zhí)行:

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

EXECUTE EMP_COUNT;

顯示結(jié)果為:

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

雇員總?cè)藬?shù)為:14
PL/SQL 過(guò)程已成功完成。

說(shuō)明:在該訓(xùn)練中,V_TOTAL變量是存儲(chǔ)過(guò)程定義的局部變量,用于接收查詢到的雇員總?cè)藬?shù)。
注意:在SQL*Plus中輸入存儲(chǔ)過(guò)程,按“執(zhí)行”按鈕是進(jìn)行編譯,不是執(zhí)行存儲(chǔ)過(guò)程。
  如果在存儲(chǔ)過(guò)程中引用了其他用戶的對(duì)象,比如表,則必須有其他用戶授予的對(duì)象訪問(wèn)權(quán)限。一個(gè)存儲(chǔ)過(guò)程一旦編譯成功,就可以由其他用戶或程序來(lái)引用。但存儲(chǔ)過(guò)程或函數(shù)的所有者必須授予其他用戶執(zhí)行該過(guò)程的權(quán)限。
存儲(chǔ)過(guò)程沒(méi)有參數(shù),在調(diào)用時(shí),直接寫過(guò)程名即可。

【訓(xùn)練2】  在PL/SQL程序中調(diào)用存儲(chǔ)過(guò)程。

步驟1:登錄SCOTT賬戶。
步驟2:授權(quán)STUDENT賬戶使用該存儲(chǔ)過(guò)程,即在SQL*Plus輸入?yún)^(qū)中,輸入以下的命令:

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

GRANT EXECUTE ON EMP_COUNT TO STUDENT

授權(quán)成功。

步驟3:登錄STUDENT賬戶,在SQL*Plus輸入?yún)^(qū)中輸入以下程序:

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

SET SERVEROUTPUT ON
  BEGIN
  SCOTT.EMP_COUNT;
  END;

步驟4:執(zhí)行以上程序,結(jié)果為:

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

雇員總?cè)藬?shù)為:14
  PL/SQL 過(guò)程已成功完成。 

說(shuō)明:在本例中,存儲(chǔ)過(guò)程是由SCOTT賬戶創(chuàng)建的,STUDEN賬戶獲得SCOTT賬戶的授權(quán)后,才能調(diào)用該存儲(chǔ)過(guò)程。
  注意:在程序中調(diào)用存儲(chǔ)過(guò)程,使用了第二種語(yǔ)法。

【訓(xùn)練3】  編寫顯示雇員信息的存儲(chǔ)過(guò)程EMP_LIST,并引用EMP_COUNT存儲(chǔ)過(guò)程。

步驟1:在SQL*Plus輸入?yún)^(qū)中輸入并編譯以下存儲(chǔ)過(guò)程:

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

CREATE OR REPLACE PROCEDURE EMP_LIST
  AS
    CURSOR emp_cursor IS
    SELECT empno,ename FROM emp;
  BEGIN
FOR Emp_record IN emp_cursor LOOP  
  DBMS_OUTPUT.PUT_LINE(Emp_record.empno||Emp_record.ename);
  END LOOP;
  EMP_COUNT;
  END;

執(zhí)行結(jié)果:

過(guò)程已創(chuàng)建。

步驟2:調(diào)用存儲(chǔ)過(guò)程,在輸入?yún)^(qū)中輸入以下語(yǔ)句并執(zhí)行:

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

EXECUTE EMP_LIST

顯示結(jié)果為:

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

7369SMITH
7499ALLEN
7521WARD
7566JONES
      執(zhí)行結(jié)果:
  雇員總?cè)藬?shù)為:14
  PL/SQL 過(guò)程已成功完成。

說(shuō)明:以上的EMP_LIST存儲(chǔ)過(guò)程中定義并使用了游標(biāo),用來(lái)循環(huán)顯示所有雇員的信息。然后調(diào)用已經(jīng)成功編譯的存儲(chǔ)過(guò)程EMP_COUNT,用來(lái)附加顯示雇員總?cè)藬?shù)。通過(guò)EXECUTE命令來(lái)執(zhí)行EMP_LIST存儲(chǔ)過(guò)程。

【練習(xí)1】編寫顯示部門信息的存儲(chǔ)過(guò)程DEPT_LIST,要求統(tǒng)計(jì)出部門個(gè)數(shù)。

參數(shù)傳遞

參數(shù)的作用是向存儲(chǔ)過(guò)程傳遞數(shù)據(jù),或從存儲(chǔ)過(guò)程獲得返回結(jié)果。正確的使用參數(shù)可以大大增加存儲(chǔ)過(guò)程的靈活性和通用性。
參數(shù)的類型有三種,如下所示。

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

IN 定義一個(gè)輸入?yún)?shù)變量,用于傳遞參數(shù)給存儲(chǔ)過(guò)程
OUT 定義一個(gè)輸出參數(shù)變量,用于從存儲(chǔ)過(guò)程獲取數(shù)據(jù)
IN OUT 定義一個(gè)輸入、輸出參數(shù)變量,兼有以上兩者的功能

參數(shù)的定義形式和作用如下:
參數(shù)名 IN 數(shù)據(jù)類型 DEFAULT 值;
定義一個(gè)輸入?yún)?shù)變量,用于傳遞參數(shù)給存儲(chǔ)過(guò)程。在調(diào)用存儲(chǔ)過(guò)程時(shí),主程序的實(shí)際參數(shù)可以是常量、有值變量或表達(dá)式等。DEFAULT 關(guān)鍵字為可選項(xiàng),用來(lái)設(shè)定參數(shù)的默認(rèn)值。如果在調(diào)用存儲(chǔ)過(guò)程時(shí)不指明參數(shù),則參數(shù)變量取默認(rèn)值。在存儲(chǔ)過(guò)程中,輸入變量接收主程序傳遞的值,但不能對(duì)其進(jìn)行賦值。
參數(shù)名 OUT 數(shù)據(jù)類型;
定義一個(gè)輸出參數(shù)變量,用于從存儲(chǔ)過(guò)程獲取數(shù)據(jù),即變量從存儲(chǔ)過(guò)程中返回值給主程序。
在調(diào)用存儲(chǔ)過(guò)程時(shí),主程序的實(shí)際參數(shù)只能是一個(gè)變量,而不能是常量或表達(dá)式。在存儲(chǔ)過(guò)程中,參數(shù)變量只能被賦值而不能將其用于賦值,在存儲(chǔ)過(guò)程中必須給輸出變量至少賦值一次。
參數(shù)名 IN OUT 數(shù)據(jù)類型 DEFAULT 值;
定義一個(gè)輸入、輸出參數(shù)變量,兼有以上兩者的功能。在調(diào)用存儲(chǔ)過(guò)程時(shí),主程序的實(shí)際參數(shù)只能是一個(gè)變量,而不能是常量或表達(dá)式。DEFAULT 關(guān)鍵字為可選項(xiàng),用來(lái)設(shè)定參數(shù)的默認(rèn)值。在存儲(chǔ)過(guò)程中,變量接收主程序傳遞的值,同時(shí)可以參加賦值運(yùn)算,也可以對(duì)其進(jìn)行賦值。在存儲(chǔ)過(guò)程中必須給變量至少賦值一次。
如果省略IN、OUT或IN OUT,則默認(rèn)模式是IN。
【訓(xùn)練1】  編寫給雇員增加工資的存儲(chǔ)過(guò)程CHANGE_SALARY,通過(guò)IN類型的參數(shù)傳遞要增加工資的雇員編號(hào)和增加的工資額。
步驟1:登錄SCOTT賬戶。
  步驟2:在SQL*Plus輸入?yún)^(qū)中輸入以下存儲(chǔ)過(guò)程并執(zhí)行:

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

CREATE OR REPLACE PROCEDURE CHANGE_SALARY(P_EMPNO IN NUMBER DEFAULT 7788,P_RAISE NUMBER DEFAULT 10)
  AS
   V_ENAME VARCHAR2(10);
V_SAL NUMBER(5);
  BEGIN
   SELECT ENAME,SAL INTO V_ENAME,V_SAL FROM EMP WHERE EMPNO=P_EMPNO;
   UPDATE EMP SET SAL=SAL+P_RAISE WHERE EMPNO=P_EMPNO;
   DBMS_OUTPUT.PUT_LINE('雇員'||V_ENAME||'的工資被改為'||TO_CHAR(V_SAL+P_RAISE));
COMMIT;
  EXCEPTION
   WHEN OTHERS THEN
   DBMS_OUTPUT.PUT_LINE('發(fā)生錯(cuò)誤,修改失敗!');
   ROLLBACK;
  END;

執(zhí)行結(jié)果為:

過(guò)程已創(chuàng)建。

步驟3:調(diào)用存儲(chǔ)過(guò)程,在輸入?yún)^(qū)中輸入以下語(yǔ)句并執(zhí)行:

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

EXECUTE CHANGE_SALARY(7788,80)

顯示結(jié)果為:

雇員SCOTT的工資被改為3080  

說(shuō)明:從執(zhí)行結(jié)果可以看到,雇員SCOTT的工資已由原來(lái)的3000改為3080。
參數(shù)的值由調(diào)用者傳遞,傳遞的參數(shù)的個(gè)數(shù)、類型和順序應(yīng)該和定義的一致。如果順序不一致,可以采用以下調(diào)用方法。如上例,執(zhí)行語(yǔ)句可以改為:
 EXECUTE CHANGE_SALARY(P_RAISE=>80,P_EMPNO=>7788);
  可以看出傳遞參數(shù)的順序發(fā)生了變化,并且明確指出了參數(shù)名和要傳遞的值,=>運(yùn)算符左側(cè)是參數(shù)名,右側(cè)是參數(shù)表達(dá)式,這種賦值方法的意義較清楚。
【練習(xí)1】創(chuàng)建插入雇員的存儲(chǔ)過(guò)程INSERT_EMP,并將雇員編號(hào)等作為參數(shù)。
在設(shè)計(jì)存儲(chǔ)過(guò)程的時(shí)候,也可以為參數(shù)設(shè)定默認(rèn)值,這樣調(diào)用者就可以不傳遞或少傳遞參數(shù)了。
【訓(xùn)練2】  調(diào)用存儲(chǔ)過(guò)程CHANGE_SALARY,不傳遞參數(shù),使用默認(rèn)參數(shù)值。
在SQL*Plus輸入?yún)^(qū)中輸入以下命令并執(zhí)行:

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

EXECUTE CHANGE_SALARY 

顯示結(jié)果為:

雇員SCOTT的工資被改為3090  

說(shuō)明:在存儲(chǔ)過(guò)程的調(diào)用中沒(méi)有傳遞參數(shù),而是采用了默認(rèn)值7788和10,即默認(rèn)雇員號(hào)為7788,增加的工資為10。
【訓(xùn)練3】  使用OUT類型的參數(shù)返回存儲(chǔ)過(guò)程的結(jié)果。
步驟1:登錄SCOTT賬戶。
步驟2:在SQL*Plus輸入?yún)^(qū)中輸入并編譯以下存儲(chǔ)過(guò)程:

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

CREATE OR REPLACE PROCEDURE EMP_COUNT(P_TOTAL OUT NUMBER)
  AS
  BEGIN
  SELECT COUNT(*) INTO P_TOTAL FROM EMP;
  END;

執(zhí)行結(jié)果為:

1.過(guò)程已創(chuàng)建。 

步驟3:輸入以下程序并執(zhí)行:

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

DECLARE
  V_EMPCOUNT NUMBER;
  BEGIN
  EMP_COUNT(V_EMPCOUNT);
  DBMS_OUTPUT.PUT_LINE('雇員總?cè)藬?shù)為:'||V_EMPCOUNT);
  END;

顯示結(jié)果為:

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

雇員總?cè)藬?shù)為:14
  PL/SQL 過(guò)程已成功完成。

 說(shuō)明:在存儲(chǔ)過(guò)程中定義了OUT類型的參數(shù)P_TOTAL,在主程序調(diào)用該存儲(chǔ)過(guò)程時(shí),傳遞了參數(shù)V_EMPCOUNT。在存儲(chǔ)過(guò)程中的SELECT...INTO...語(yǔ)句中對(duì)P_TOTAL進(jìn)行賦值,賦值結(jié)果由V_EMPCOUNT變量帶回給主程序并顯示。
以上程序要覆蓋同名的EMP_COUNT存儲(chǔ)過(guò)程,如果不使用OR REPLACE選項(xiàng),就會(huì)出現(xiàn)以下錯(cuò)誤:

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

ERROR 位于第 1 行:
  ORA-00955: 名稱已由現(xiàn)有對(duì)象使用。

【練習(xí)2】創(chuàng)建存儲(chǔ)過(guò)程,使用OUT類型參數(shù)獲得雇員經(jīng)理名。
【訓(xùn)練4】  使用IN OUT類型的參數(shù),給電話號(hào)碼增加區(qū)碼。
步驟1:登錄SCOTT賬戶。
步驟2:在SQL*Plus輸入?yún)^(qū)中輸入并編譯以下存儲(chǔ)過(guò)程:

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

CREATE OR REPLACE PROCEDURE ADD_REGION(P_HPONE_NUM IN OUT VARCHAR2)
  AS
  BEGIN
   P_HPONE_NUM:='0755-'||P_HPONE_NUM;
  END;

執(zhí)行結(jié)果為:

過(guò)程已創(chuàng)建。 

步驟3:輸入以下程序并執(zhí)行:

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

SET SERVEROUTPUT ON
DECLARE
V_PHONE_NUM VARCHAR2(15);
BEGIN
V_PHONE_NUM:='26731092';
ADD_REGION(V_PHONE_NUM);
DBMS_OUTPUT.PUT_LINE('新的電話號(hào)碼:'||V_PHONE_NUM);
END;

顯示結(jié)果為:

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

新的電話號(hào)碼:0755-26731092
  PL/SQL 過(guò)程已成功完成。

說(shuō)明:變量V_HPONE_NUM既用來(lái)向存儲(chǔ)過(guò)程傳遞舊電話號(hào)碼,也用來(lái)向主程序返回新號(hào)碼。新的號(hào)碼在原來(lái)基礎(chǔ)上增加了區(qū)號(hào)0755和-。

創(chuàng)建和刪除存儲(chǔ)函數(shù)

  創(chuàng)建函數(shù),需要有CREATE PROCEDURE或CREATE ANY PROCEDURE的系統(tǒng)權(quán)限。該權(quán)限可由系統(tǒng)管理員授予。創(chuàng)建存儲(chǔ)函數(shù)的語(yǔ)法和創(chuàng)建存儲(chǔ)過(guò)程的類似,即
CREATE [OR REPLACE] FUNCTION 函數(shù)名[(參數(shù)[IN] 數(shù)據(jù)類型...)]
RETURN 數(shù)據(jù)類型
{AS|IS}
[說(shuō)明部分]
BEGIN
可執(zhí)行部分
RETURN (表達(dá)式)
[EXCEPTION
    錯(cuò)誤處理部分]
END [函數(shù)名];
其中,參數(shù)是可選的,但只能是IN類型(IN關(guān)鍵字可以省略)。
在定義部分的RETURN 數(shù)據(jù)類型,用來(lái)表示函數(shù)的數(shù)據(jù)類型,也就是返回值的類型,此部分不可省略。
在可執(zhí)行部分的RETURN(表達(dá)式),用來(lái)生成函數(shù)的返回值,其表達(dá)式的類型應(yīng)該和定義部分說(shuō)明的函數(shù)返回值的數(shù)據(jù)類型一致。在函數(shù)的執(zhí)行部分可以有多個(gè)RETURN語(yǔ)句,但只有一個(gè)RETURN語(yǔ)句會(huì)被執(zhí)行,一旦執(zhí)行了RETURN語(yǔ)句,則函數(shù)結(jié)束并返回調(diào)用環(huán)境。
一個(gè)存儲(chǔ)函數(shù)在不需要時(shí)可以刪除,但刪除的人應(yīng)是函數(shù)的創(chuàng)建者或者是擁有DROP ANY PROCEDURE系統(tǒng)權(quán)限的人。其語(yǔ)法如下:
DROP FUNCTION 函數(shù)名;
重新編譯一個(gè)存儲(chǔ)函數(shù)時(shí),編譯的人應(yīng)是函數(shù)的創(chuàng)建者或者擁有ALTER ANY PROCEDURE系統(tǒng)權(quán)限的人。重新編譯一個(gè)存儲(chǔ)函數(shù)的語(yǔ)法如下:
ALTER PROCEDURE 函數(shù)名 COMPILE;
函數(shù)的調(diào)用者應(yīng)是函數(shù)的創(chuàng)建者或擁有EXECUTE ANY PROCEDURE系統(tǒng)權(quán)限的人,或是被函數(shù)的擁有者授予了函數(shù)執(zhí)行權(quán)限的賬戶。函數(shù)的引用和存儲(chǔ)過(guò)程不同,函數(shù)要出現(xiàn)在程序體中,可以參加表達(dá)式的運(yùn)算或單獨(dú)出現(xiàn)在表達(dá)式中,其形式如下:
變量名:=函數(shù)名(...)

【訓(xùn)練1】  創(chuàng)建一個(gè)通過(guò)雇員編號(hào)返回雇員名稱的函數(shù)GET_EMP_NAME。
步驟1:登錄SCOTT賬戶。
步驟2:在SQL*Plus輸入?yún)^(qū)中輸入以下存儲(chǔ)函數(shù)并編譯:

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

CREATE OR REPLACE FUNCTION GET_EMP_NAME(P_EMPNO NUMBER DEFAULT 7788)
  RETURN VARCHAR2
  AS
   V_ENAME VARCHAR2(10);
  BEGIN
   ELECT ENAME INTO V_ENAME FROM EMP WHERE EMPNO=P_EMPNO;
RETURN(V_ENAME);
EXCEPTION
 WHEN NO_DATA_FOUND THEN
  DBMS_OUTPUT.PUT_LINE('沒(méi)有該編號(hào)雇員!');
  RETURN (NULL);
 WHEN TOO_MANY_ROWS THEN
  DBMS_OUTPUT.PUT_LINE('有重復(fù)雇員編號(hào)!');
  RETURN (NULL);
 WHEN OTHERS THEN
  DBMS_OUTPUT.PUT_LINE('發(fā)生其他錯(cuò)誤!');
  RETURN (NULL);
END;

步驟3:調(diào)用該存儲(chǔ)函數(shù),輸入并執(zhí)行以下程序:

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

BEGIN
    DBMS_OUTPUT.PUT_LINE('雇員7369的名稱是:'|| GET_EMP_NAME(7369));
    DBMS_OUTPUT.PUT_LINE('雇員7839的名稱是:'|| GET_EMP_NAME(7839));
  END;

顯示結(jié)果為:

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

雇員7369的名稱是:SMITH
  雇員7839的名稱是:KING
  PL/SQL 過(guò)程已成功完成。

說(shuō)明:函數(shù)的調(diào)用直接出現(xiàn)在程序的DBMS_OUTPUT.PUT_LINE語(yǔ)句中,作為字符串表達(dá)式的一部分。如果輸入了錯(cuò)誤的雇員編號(hào),就會(huì)在函數(shù)的錯(cuò)誤處理部分輸出錯(cuò)誤信息。試修改雇員編號(hào),重新運(yùn)行調(diào)用部分。
【練習(xí)1】創(chuàng)建一個(gè)通過(guò)部門編號(hào)返回部門名稱的存儲(chǔ)函數(shù)GET_DEPT_NAME。
   【練習(xí)2】將函數(shù)的執(zhí)行權(quán)限授予STUDENT賬戶,然后登錄STUDENT賬戶調(diào)用。
存儲(chǔ)過(guò)程和函數(shù)的查看
可以通過(guò)對(duì)數(shù)據(jù)字典的訪問(wèn)來(lái)查詢存儲(chǔ)過(guò)程或函數(shù)的有關(guān)信息,如果要查詢當(dāng)前用戶的存儲(chǔ)過(guò)程或函數(shù)的源代碼,可以通過(guò)對(duì)USER_SOURCE數(shù)據(jù)字典視圖的查詢得到。USER_SOURCE的結(jié)構(gòu)如下:

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

DESCRIBE USER_SOURCE

結(jié)果為:

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

名稱                                      是否為空? 類型
   ------------------------------------------------------------- ------------- -----------------------
 NAME                                             VARCHAR2(30)
 TYPE                                              VARCHAR2(12)
 LINE                                              NUMBER
 TEXT                                              VARCHAR2(4000)

說(shuō)明:里面按行存放著過(guò)程或函數(shù)的腳本,NAME是過(guò)程或函數(shù)名,TYPE 代表類型(PROCEDURE或FUNCTION),LINE是行號(hào),TEXT 為腳本。
【訓(xùn)練1】  查詢過(guò)程EMP_COUNT的腳本。
在SQL*Plus中輸入并執(zhí)行如下查詢:

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

select TEXT  from user_source WHERE NAME='EMP_COUNT';

結(jié)果為:

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

TEXT
--------------------------------------------------------------------------------
PROCEDURE EMP_COUNT(P_TOTAL OUT NUMBER)
AS
BEGIN
 SELECT COUNT(*) INTO P_TOTAL FROM EMP;
END;

【訓(xùn)練2】  查詢過(guò)程GET_EMP_NAME的參數(shù)。
在SQL*Plus中輸入并執(zhí)行如下查詢:

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

DESCRIBE GET_EMP_NAME

結(jié)果為:

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

FUNCTION GET_EMP_NAME RETURNS VARCHAR2
  參數(shù)名稱            類型          輸入/輸出默認(rèn)值?
  ----------------------------------------- ----------------------------------- ----------------- -------------
   P_EMPNO             NUMBER(4) IN     DEFAULT

【訓(xùn)練3】  在發(fā)生編譯錯(cuò)誤時(shí),顯示錯(cuò)誤。

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

SHOW ERRORS

以下是一段編譯錯(cuò)誤顯示:

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

LINE/COL ERROR
  ------------- -----------------------------------------------------------------
  4/2       PL/SQL: SQL Statement ignored
  4/36      PLS-00201: 必須說(shuō)明標(biāo)識(shí)符 'EMPP'

說(shuō)明:查詢一個(gè)存儲(chǔ)過(guò)程或函數(shù)是否是有效狀態(tài)(即編譯成功),可以使用數(shù)據(jù)字典USER_OBJECTS的STATUS列。
【訓(xùn)練4】  查詢EMP_LIST存儲(chǔ)過(guò)程是否可用:

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

SELECT STATUS FROM USER_OBJECTS WHERE OBJECT_NAME='EMP_LIST';

結(jié)果為:

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

STATUS
  ------------
  VALID

說(shuō)明:VALID表示該存儲(chǔ)過(guò)程有效(即通過(guò)編譯),INVALID表示存儲(chǔ)過(guò)程無(wú)效或需要重新編譯。當(dāng)Oracle調(diào)用一個(gè)無(wú)效的存儲(chǔ)過(guò)程或函數(shù)時(shí),首先試圖對(duì)其進(jìn)行編譯,如果編譯成功則將狀態(tài)置成VALID并執(zhí)行,否則給出錯(cuò)誤信息。
當(dāng)一個(gè)存儲(chǔ)過(guò)程編譯成功,狀態(tài)變?yōu)閂ALID,會(huì)不會(huì)在某些情況下變成INVALID。結(jié)論是完全可能的。比如一個(gè)存儲(chǔ)過(guò)程中包含對(duì)表的查詢,如果表被修改或刪除,存儲(chǔ)過(guò)程就會(huì)變成無(wú)效INVALID。所以要注意存儲(chǔ)過(guò)程和函數(shù)對(duì)其他對(duì)象的依賴關(guān)系。
如果要檢查存儲(chǔ)過(guò)程或函數(shù)的依賴性,可以通過(guò)查詢數(shù)據(jù)字典USER_DENPENDENCIES來(lái)確定,該表結(jié)構(gòu)如下:

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

DESCRIBE USER_DEPENDENCIES;

結(jié)果:

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

名稱                     是否為空? 類型
   -------------------------------------------------------------- ------------- ----------------------------
   NAME            NOT NULL VARCHAR2(30)
   TYPE                       VARCHAR2(12)
  REFERENCED_OWNER                              VARCHAR2(30)
 REFERENCED_NAME                               VARCHAR2(64)
 REFERENCED_TYPE                                VARCHAR2(12)
REFERENCED_LINK_NAME                         VARCHAR2(128)
   SCHEMAID                                        NUMBER
   DEPENDENCY_TYPE                                VARCHAR2(4)

說(shuō)明:NAME為實(shí)體名,TYPE為實(shí)體類型,REFERENCED_OWNER為涉及到的實(shí)體擁有者賬戶,REFERENCED_NAME為涉及到的實(shí)體名,REFERENCED_TYPE 為涉及到的實(shí)體類型。
【訓(xùn)練5】  查詢EMP_LIST存儲(chǔ)過(guò)程的依賴性。

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

SELECT REFERENCED_NAME,REFERENCED_TYPE FROM USER_DEPENDENCIES WHERE NAME='EMP_LIST';

執(zhí)行結(jié)果:

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

REFERENCED_NAME                                         REFERENCED_TYPE
  ------------------------------------------------------------------------------------------ ----------------------------
STANDARD                                               PACKAGE
  SYS_STUB_FOR_PURITY_ANALYSIS                           PACKAGE
  DBMS_OUTPUT                                              PACKAGE
  DBMS_OUTPUT                                             SYNONYM
DBMS_OUTPUT                      NON-EXISTENT
  EMP                                                        TABLE
  EMP_COUNT                                                 PROCEDURE

說(shuō)明:可以看出存儲(chǔ)過(guò)程EMP_LIST依賴一些系統(tǒng)包、EMP表和EMP_COUNT存儲(chǔ)過(guò)程。如果刪除了EMP表或EMP_COUNT存儲(chǔ)過(guò)程,EMP_LIST將變成無(wú)效。
還有一種情況需要我們注意:如果一個(gè)用戶A被授予執(zhí)行屬于用戶B的一個(gè)存儲(chǔ)過(guò)程的權(quán)限,在用戶B的存儲(chǔ)過(guò)程中,訪問(wèn)到用戶C的表,用戶B被授予訪問(wèn)用戶C的表的權(quán)限,但用戶A沒(méi)有被授予訪問(wèn)用戶C表的權(quán)限,那么用戶A調(diào)用用戶B的存儲(chǔ)過(guò)程是失敗的還是成功的呢?答案是成功的。如果讀者有興趣,不妨進(jìn)行一下實(shí)際測(cè)試。


包的概念和組成

包是用來(lái)存儲(chǔ)相關(guān)程序結(jié)構(gòu)的對(duì)象,它存儲(chǔ)于數(shù)據(jù)字典中。包由兩個(gè)分離的部分組成:包頭(PACKAGE)和包體(PACKAGE BODY)。包頭是包的說(shuō)明部分,是對(duì)外的操作接口,對(duì)應(yīng)用是可見(jiàn)的;包體是包的代碼和實(shí)現(xiàn)部分,對(duì)應(yīng)用來(lái)說(shuō)是不可見(jiàn)的黑盒。
包中可以包含的程序結(jié)構(gòu)如下所示。

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

過(guò)程(PROCUDURE) 帶參數(shù)的命名的程序模塊
函數(shù)(FUNCTION) 帶參數(shù)、具有返回值的命名的程序模塊
變量(VARIABLE) 存儲(chǔ)變化的量的存儲(chǔ)單元
常量(CONSTANT) 存儲(chǔ)不變的量的存儲(chǔ)單元
游標(biāo)(CURSOR) 用戶定義的數(shù)據(jù)操作緩存區(qū),在可執(zhí)行部分使用
類型(TYPE) 用戶定義的新的結(jié)構(gòu)類型
異常(EXCEPTION) 在標(biāo)準(zhǔn)包中定義或由用戶自定義,用于處理程序錯(cuò)誤

說(shuō)明部分可以出現(xiàn)在包的三個(gè)不同的部分:出現(xiàn)在包頭中的稱為公有元素,出現(xiàn)在包體中的稱為私有元素,出現(xiàn)在包體的過(guò)程(或函數(shù))中的稱為局部變量。它們的性質(zhì)有所不同,如下所示。

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

公有元素(PUBLIC) 在包頭中說(shuō)明,在包體中具體定義 在包外可見(jiàn)并可以訪問(wèn),對(duì)整個(gè)應(yīng)用的全過(guò)程有效
私有元素(PRIVATE) 在包體的說(shuō)明部分說(shuō)明 只能被包內(nèi)部的其他部分訪問(wèn)
局部變量(LOCAL) 在過(guò)程或函數(shù)的說(shuō)明部分說(shuō)明 只能在定義變量的過(guò)程或函數(shù)中使用

在包體中出現(xiàn)的過(guò)程或函數(shù),如果需要對(duì)外公用,就必須在包頭中說(shuō)明,包頭中的說(shuō)明應(yīng)該和包體中的說(shuō)明一致。
包有以下優(yōu)點(diǎn):
* 包可以方便地將存儲(chǔ)過(guò)程和函數(shù)組織到一起,每個(gè)包又是相互獨(dú)立的。在不同的包中,過(guò)程、函數(shù)都可以重名,這解決了在同一個(gè)用戶環(huán)境中命名的沖突問(wèn)題。
* 包增強(qiáng)了對(duì)存儲(chǔ)過(guò)程和函數(shù)的安全管理,對(duì)整個(gè)包的訪問(wèn)權(quán)只需一次授予。
  * 在同一個(gè)會(huì)話中,公用變量的值將被保留,直到會(huì)話結(jié)束。
* 區(qū)分了公有過(guò)程和私有過(guò)程,包體的私有過(guò)程增加了過(guò)程和函數(shù)的保密性。
* 包在被首次調(diào)用時(shí),就作為一個(gè)整體被全部調(diào)入內(nèi)存,減少了多次訪問(wèn)過(guò)程或函數(shù)的I/O次數(shù)。
創(chuàng)建包和包體
包由包頭和包體兩部分組成,包的創(chuàng)建應(yīng)該先創(chuàng)建包頭部分,然后創(chuàng)建包體部分。創(chuàng)建、刪除和編譯包的權(quán)限同創(chuàng)建、刪除和編譯存儲(chǔ)過(guò)程的權(quán)限相同。
創(chuàng)建包頭的簡(jiǎn)要語(yǔ)句如下:
CREATE [OR REPLACE] PACKAGE 包名
{IS|AS}
公有變量定義
公有類型定義
公有游標(biāo)定義
公有異常定義
函數(shù)說(shuō)明
過(guò)程說(shuō)明
END;
創(chuàng)建包體的簡(jiǎn)要語(yǔ)法如下:
CREATE [OR REPLACE] PACKAGE BODY 包名
{IS|AS}
私有變量定義
私有類型定義
私有游標(biāo)定義
私有異常定義
函數(shù)定義
過(guò)程定義
END;
包的其他操作命令包括:
刪除包頭:
DROP PACKAGE 包頭名
刪除包體:
DROP PACKAGE BODY 包體名
重新編譯包頭:
ALTER PACKAGE 包名 COMPILE PACKAGE
重新編譯包體:
ALTER PACKAGE 包名 COMPILE PACKAGE BODY
在包頭中說(shuō)明的對(duì)象可以在包外調(diào)用,調(diào)用的方法和調(diào)用單獨(dú)的過(guò)程或函數(shù)的方法基本相同,惟一的區(qū)別就是要在調(diào)用的過(guò)程或函數(shù)名前加上包的名字(中間用“.”分隔)。但要注意,不同的會(huì)話將單獨(dú)對(duì)包的公用變量進(jìn)行初始化,所以不同的會(huì)話對(duì)包的調(diào)用屬于不同的應(yīng)用。
系統(tǒng)包
Oracle預(yù)定義了很多標(biāo)準(zhǔn)的系統(tǒng)包,這些包可以在應(yīng)用中直接使用,比如在訓(xùn)練中我們使用的DBMS_OUTPUT包,就是系統(tǒng)包。PUT_LINE是該包的一個(gè)函數(shù)。常用系統(tǒng)包下所示。

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

DBMS_OUTPUT 在SQL*Plus環(huán)境下輸出信息
DBMS_DDL 編譯過(guò)程函數(shù)和包
DBMS_SESSION 改變用戶的會(huì)話,初始化包等
DBMS_TRANSACTION 控制數(shù)據(jù)庫(kù)事務(wù)
DBMS_MAIL 連接Oracle*Mail
DBMS_LOCK 進(jìn)行復(fù)雜的鎖機(jī)制管理
DBMS_ALERT 識(shí)別數(shù)據(jù)庫(kù)事件告警
DBMS_PIPE 通過(guò)管道在會(huì)話間傳遞信息
DBMS_JOB 管理Oracle的作業(yè)
DBMS_LOB 操縱大對(duì)象
DBMS_SQL 執(zhí)行動(dòng)態(tài)SQL語(yǔ)句

包的應(yīng)用

在SQL*Plus環(huán)境下,包和包體可以分別編譯,也可以一起編譯。如果分別編譯,則要先編譯包頭,后編譯包體。如果在一起編譯,則包頭寫在前,包體在后,中間用“/”分隔。
可以將已經(jīng)存在的存儲(chǔ)過(guò)程或函數(shù)添加到包中,方法是去掉過(guò)程或函數(shù)創(chuàng)建語(yǔ)句的CREATE OR REPLACE部分,將存儲(chǔ)過(guò)程或函數(shù)復(fù)制到包體中 ,然后重新編譯即可。
   如果需要將私有過(guò)程或函數(shù)變成共有過(guò)程或函數(shù)的話,將過(guò)程或函數(shù)說(shuō)明部分復(fù)制到包頭說(shuō)明部分,然后重新編譯就可以了。
【訓(xùn)練1】  創(chuàng)建管理雇員信息的包EMPLOYE,它具有從EMP表獲得雇員信息,修改雇員名稱,修改雇員工資和寫回EMP表的功能。
步驟1:登錄SCOTT賬戶,輸入以下代碼并編譯:

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

CREATE OR REPLACE PACKAGE EMPLOYE --包頭部分
  IS
 PROCEDURE SHOW_DETAIL;
 PROCEDURE GET_EMPLOYE(P_EMPNO NUMBER);
 PROCEDURE SAVE_EMPLOYE;
 PROCEDURE CHANGE_NAME(P_NEWNAME VARCHAR2);
PROCEDURE CHANGE_SAL(P_NEWSAL NUMBER);
  END EMPLOYE;
  /
  CREATE OR REPLACE PACKAGE BODY EMPLOYE --包體部分
  IS
 EMPLOYE EMP%ROWTYPE;
  -------------- 顯示雇員信息 ---------------
  PROCEDURE SHOW_DETAIL
   AS
   BEGIN
DBMS_OUTPUT.PUT_LINE(‘----- 雇員信息 -----'); 
    DBMS_OUTPUT.PUT_LINE('雇員編號(hào):'||EMPLOYE.EMPNO);
    DBMS_OUTPUT.PUT_LINE('雇員名稱:'||EMPLOYE.ENAME);
    DBMS_OUTPUT.PUT_LINE('雇員職務(wù):'||EMPLOYE.JOB);
    DBMS_OUTPUT.PUT_LINE('雇員工資:'||EMPLOYE.SAL);
    DBMS_OUTPUT.PUT_LINE('部門編號(hào):'||EMPLOYE.DEPTNO);
   END SHOW_DETAIL;
----------------- 從EMP表取得一個(gè)雇員 --------------------
   PROCEDURE GET_EMPLOYE(P_EMPNO NUMBER)
   AS
   BEGIN
    SELECT * INTO EMPLOYE FROM EMP WHERE  EMPNO=P_EMPNO;
    DBMS_OUTPUT.PUT_LINE('獲取雇員'||EMPLOYE.ENAME||'信息成功');
   EXCEPTION
    WHEN OTHERS THEN
     DBMS_OUTPUT.PUT_LINE('獲取雇員信息發(fā)生錯(cuò)誤!');
   END GET_EMPLOYE;
---------------------- 保存雇員到EMP表 --------------------------
   PROCEDURE SAVE_EMPLOYE
   AS
   BEGIN
    UPDATE EMP SET ENAME=EMPLOYE.ENAME, SAL=EMPLOYE.SAL WHERE EMPNO=
 EMPLOYE.EMPNO;
   DBMS_OUTPUT.PUT_LINE('雇員信息保存完成!');
   END SAVE_EMPLOYE;
---------------------------- 修改雇員名稱 ------------------------------
   PROCEDURE CHANGE_NAME(P_NEWNAME VARCHAR2)
   AS
   BEGIN
    EMPLOYE.ENAME:=P_NEWNAME;
    DBMS_OUTPUT.PUT_LINE('修改名稱完成!');
   END CHANGE_NAME;
---------------------------- 修改雇員工資 --------------------------
   PROCEDURE CHANGE_SAL(P_NEWSAL NUMBER)
   AS
   BEGIN
    EMPLOYE.SAL:=P_NEWSAL;
    DBMS_OUTPUT.PUT_LINE('修改工資完成!');
   END CHANGE_SAL;
  END EMPLOYE;


步驟2:獲取雇員7788的信息:

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

SET SERVEROUTPUT ON
  EXECUTE EMPLOYE.GET_EMPLOYE(7788);

結(jié)果為:

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

獲取雇員SCOTT信息成功
  PL/SQL 過(guò)程已成功完成。

步驟3:顯示雇員信息:

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

EXECUTE EMPLOYE.SHOW_DETAIL;

結(jié)果為:

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

------------------ 雇員信息 ------------------
  雇員編號(hào):7788
  雇員名稱:SCOTT
  雇員職務(wù):ANALYST
  雇員工資:3000
  部門編號(hào):20
  PL/SQL 過(guò)程已成功完成。

步驟4:修改雇員工資:

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

EXECUTE EMPLOYE.CHANGE_SAL(3800);

結(jié)果為:

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

修改工資完成!
  PL/SQL 過(guò)程已成功完成。

步驟5:將修改的雇員信息存入EMP表

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

EXECUTE EMPLOYE.SAVE_EMPLOYE;

結(jié)果為:

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

雇員信息保存完成!
  PL/SQL 過(guò)程已成功完成。

說(shuō)明:該包完成將EMP表中的某個(gè)雇員的信息取入內(nèi)存記錄變量,在記錄變量中進(jìn)行修改編輯,在確認(rèn)顯示信息正確后寫回EMP表的功能。記錄變量EMPLOYE用來(lái)存儲(chǔ)取得的雇員信息,定義為私有變量,只能被包的內(nèi)部模塊訪問(wèn)。
  【練習(xí)1】為包增加修改雇員職務(wù)和部門編號(hào)的功能。

階段訓(xùn)練
下面的訓(xùn)練通過(guò)定義和創(chuàng)建完整的包EMP_PK并綜合運(yùn)用本章的知識(shí),完成對(duì)雇員表的插入、刪除等功能,包中的主要元素解釋如下所示。

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

程序結(jié)構(gòu) 類  型 說(shuō)    明
V_EMP_COUNT 公有變量 跟蹤雇員的總?cè)藬?shù)變化,插入、刪除雇員的同時(shí)修改該變量的值
INIT 公有過(guò)程 對(duì)包進(jìn)行初始化,初始化雇員人數(shù)和工資修改的上、下限
LIST_EMP 公有過(guò)程 顯示雇員列表
INSERT_EMP 公有過(guò)程 通過(guò)編號(hào)插入新雇員
DELETE_EMP 公有過(guò)程 通過(guò)編號(hào)刪除雇員
CHANGE_EMP_SAL 公有過(guò)程 通過(guò)編號(hào)修改雇員工資
V_MESSAGE 私有變量 存放準(zhǔn)備輸出的信息
C_MAX_SAL 私有變量 對(duì)工資修改的上限
C_MIN_SAL 私有變量 對(duì)工資修改的下限
SHOW_MESSAGE 私有過(guò)程 顯示私有變量V_MESSAGE中的信息
EXIST_EMP 私有函數(shù) 判斷某個(gè)編號(hào)的雇員是否存在,該函數(shù)被INSERT_EMP、DELETE_EMP和CHANGE_EMP_SAL等過(guò)程調(diào)用

【訓(xùn)練1】  完整的雇員包EMP_PK的創(chuàng)建和應(yīng)用。
步驟1:在SQL*Plus中登錄SCOTT賬戶,輸入以下包頭和包體部分,按“執(zhí)行”按鈕編譯:

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

CREATE OR REPLACE PACKAGE EMP_PK
  --包頭部分
  IS
   V_EMP_COUNT NUMBER(5);     
  --雇員人數(shù)
   PROCEDURE INIT(P_MAX NUMBER,P_MIN NUMBER);  --初始化
   PROCEDURE LIST_EMP;      
  --顯示雇員列表
PROCEDURE INSERT_EMP(P_EMPNO   NUMBER,P_ENAMEVARCHAR2,P_JOB VARCHAR2,
   P_SAL NUMBER);       
  --插入雇員
  PROCEDURE DELETE_EMP(P_EMPNO NUMBER);   --刪除雇員
   PROCEDURE CHANGE_EMP_SAL(P_EMPNO NUMBER,P_SAL NUMBER);
  --修改雇員工資
  END EMP_PK;
  /CREATE OR REPLACE PACKAGE BODY EMP_PK
   --包體部分
  IS
   V_MESSAGE VARCHAR2(50); --顯示信息
V_MAX_SAL NUMBER(7); --工資上限
   V_MIN_SAL NUMBER(7); --工資下限
   FUNCTION EXIST_EMP(P_EMPNO NUMBER)  RETURN  BOOLEAN; --判斷雇員是否存在函數(shù)
   PROCEDURE SHOW_MESSAGE; --顯示信息過(guò)程
  ------------------------------- 初始化過(guò)程 ----------------------------
   PROCEDURE INIT(P_MAX NUMBER,P_MIN NUMBER)
  IS
  BEGIN
      SELECT COUNT(*) INTO V_EMP_COUNT FROM EMP;
V_MAX_SAL:=P_MAX;
    V_MIN_SAL:=P_MIN;
    V_MESSAGE:='初始化過(guò)程已經(jīng)完成!';
    SHOW_MESSAGE;
   END INIT;
---------------------------- 顯示雇員列表過(guò)程 ---------------------
  PROCEDURE LIST_EMP
   IS
   BEGIN
DBMS_OUTPUT.PUT_LINE('姓名       職務(wù)      工資');
    FOR emp_rec IN (SELECT * FROM EMP)
    LOOP
  DBMS_OUTPUT.PUT_LINE(RPAD(emp_rec.ename,10,'')||RPAD(emp_rec.job,10,' ')||TO_CHAR(emp_rec.sal));
    END LOOP;
    DBMS_OUTPUT.PUT_LINE('雇員總?cè)藬?shù)'||V_EMP_COUNT);
   END LIST_EMP;
----------------------------- 插入雇員過(guò)程 -----------------------------
   PROCEDUREINSERT_EMP(P_EMPNO  NUMBER,P_ENAMEVARCHAR2,P_JOB  VARCHAR2,P_SAL NUMBER)
   IS
   BEGIN
   IF NOT EXIST_EMP(P_EMPNO) THEN
    INSERT INTO EMP(EMPNO,ENAME,JOB,SAL)   VALUES(P_EMPNO,P_ENAME,P_JOB,P_SAL);
  COMMIT; 
     V_EMP_COUNT:=V_EMP_COUNT+1;
    V_MESSAGE:='雇員'||P_EMPNO||'已插入!';
    ELSE
V_MESSAGE:='雇員'||P_EMPNO||'已存在,不能插入!';
   END IF;
   SHOW_MESSAGE;
  EXCEPTION
   WHEN OTHERS THEN
    V_MESSAGE:='雇員'||P_EMPNO||'插入失敗!';
    SHOW_MESSAGE;
  END INSERT_EMP;
--------------------------- 刪除雇員過(guò)程 --------------------
   PROCEDURE DELETE_EMP(P_EMPNO NUMBER)
   IS
   BEGIN
    IF EXIST_EMP(P_EMPNO) THEN
     DELETE FROM EMP WHERE EMPNO=P_EMPNO;
     COMMIT;
     V_EMP_COUNT:=V_EMP_COUNT-1;
     V_MESSAGE:='雇員'||P_EMPNO||'已刪除!';
    ELSE
V_MESSAGE:='雇員'||P_EMPNO||'不存在,不能刪除!';
   END IF;
   SHOW_MESSAGE;
  EXCEPTION
   WHEN OTHERS THEN
    V_MESSAGE:='雇員'||P_EMPNO||'刪除失敗!';
    SHOW_MESSAGE;
  END DELETE_EMP;
--------------------------------------- 修改雇員工資過(guò)程 ------------------------------------
   PROCEDURE CHANGE_EMP_SAL(P_EMPNO NUMBER,P_SAL NUMBER)
   IS
   BEGIN
    IF (P_SAL>V_MAX_SAL OR P_SAL<V_MIN_SAL) THEN
     V_MESSAGE:='工資超出修改范圍!';
    ELSIF NOT EXIST_EMP(P_EMPNO) THEN
     V_MESSAGE:='雇員'||P_EMPNO||'不存在,不能修改工資!';
ELSE
     UPDATE EMP SET SAL=P_SAL WHERE EMPNO=P_EMPNO;
     COMMIT;
     V_MESSAGE:='雇員'||P_EMPNO||'工資已經(jīng)修改!';
    END IF;
    SHOW_MESSAGE;
   EXCEPTION
    WHEN OTHERS THEN
     V_MESSAGE:='雇員'||P_EMPNO||'工資修改失敗!';
     SHOW_MESSAGE;
   END CHANGE_EMP_SAL;
---------------------------- 顯示信息過(guò)程 ----------------------------
   PROCEDURE SHOW_MESSAGE
   IS
   BEGIN
    DBMS_OUTPUT.PUT_LINE('提示信息:'||V_MESSAGE);
   END SHOW_MESSAGE;
------------------------ 判斷雇員是否存在函數(shù) -------------------
   FUNCTION EXIST_EMP(P_EMPNO NUMBER)
   RETURN BOOLEAN
   IS
    V_NUM NUMBER; --局部變量
   BEGIN
    SELECT COUNT(*) INTO V_NUM FROM EMP WHERE EMPNO=P_EMPNO;
IF V_NUM=1 THEN
     RETURN TRUE;
    ELSE
     RETURN FALSE;
    END IF;
   END EXIST_EMP;
  -----------------------------
  END EMP_PK;

結(jié)果為:

1.程序包已創(chuàng)建。  
2.        程序包主體已創(chuàng)建。 

步驟2:初始化包:

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

SET SERVEROUTPUT ON
EXECUTE EMP_PK.INIT(6000,600);

顯示為:

提示信息:初始化過(guò)程已經(jīng)完成! 

步驟3:顯示雇員列表:

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

EXECUTE EMP_PK.LIST_EMP;

顯示為:

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

姓名        職務(wù)       工資
  SMITH      CLERK      1560
  ALLEN      SALESMAN   1936
  WARD      SALESMAN   1830
  JONES      MANAGER    2975
  ...
  雇員總?cè)藬?shù):14
  PL/SQL 過(guò)程已成功完成。

步驟4:插入一個(gè)新記錄:

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

EXECUTE EMP_PK.INSERT_EMP(8001,'小王','CLERK',1000);

顯示結(jié)果為:

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

提示信息:雇員8001已插入!
PL/SQL 過(guò)程已成功完成。

步驟5:通過(guò)全局變量V_EMP_COUNT查看雇員人數(shù):

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

BEGIN
DBMS_OUTPUT.PUT_LINE(EMP_PK.V_EMP_COUNT);
END;

顯示結(jié)果為:

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

15
PL/SQL 過(guò)程已成功完成。

步驟6:刪除新插入記錄:

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

EXECUTE EMP_PK.DELETE_EMP(8001);

顯示結(jié)果為:

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

提示信息:雇員8001已刪除!
  PL/SQL 過(guò)程已成功完成。

再次刪除該雇員:

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

EXECUTE EMP_PK.DELETE_EMP(8001);

結(jié)果為:

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

提示信息:雇員8001不存在,不能刪除!

步驟7:修改雇員工資:

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

EXECUTE EMP_PK.CHANGE_EMP_SAL(7788,8000);

顯示結(jié)果為:

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

提示信息:工資超出修改范圍!
  PL/SQL 過(guò)程已成功完成。

步驟8:授權(quán)其他用戶調(diào)用包:
如果是另外一個(gè)用戶要使用該包,必須由包的所有者授權(quán),下面授予STUDEN賬戶對(duì)該包的使用權(quán):

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

GRANT EXECUTE ON EMP_PK TO STUDENT;

每一個(gè)新的會(huì)話要為包中的公用變量開(kāi)辟新的存儲(chǔ)空間,所以需要重新執(zhí)行初始化過(guò)程。兩個(gè)會(huì)話的進(jìn)程互不影響。
步驟9:其他用戶調(diào)用包。
啟動(dòng)另外一個(gè)SQL*Plus,登錄STUDENT賬戶,執(zhí)行以下過(guò)程:

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

SET SERVEROUTPUT ON
  EXECUTE SCOTT.EMP_PK. EMP_PK.INIT(5000,700);

結(jié)果為:

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

提示信息:初始化過(guò)程已經(jīng)完成!
  PL/SQL 過(guò)程已成功完成。

說(shuō)明:在初始化中設(shè)置雇員的總?cè)藬?shù)和修改工資的上、下限,初始化后V_EMP_COUNT為14人,插入雇員后V_EMP_COUNT為15人。V_EMP_COUNT為公有變量,所以可以在外部程序中使用DBMS_OUTPUT.PUT_LINE輸出,引用時(shí)用EMP_PK.V_EMP_COUNT的形式,說(shuō)明所屬的包。而私有變量V_MAX_SAL和V_MIN_SAL不能被外部訪問(wèn),只能通過(guò)內(nèi)部過(guò)程來(lái)修改。同樣,EXIST_EMP和SHOW_MESSAGE也是私有過(guò)程,也只能在過(guò)程體內(nèi)被其他模塊引用。
注意:在最后一個(gè)步驟中,因?yàn)镾TUDENT模式調(diào)用了SCOTT模式的包,所以包名前要增加模式名SCOTT。不同的會(huì)話對(duì)包的調(diào)用屬于不同的應(yīng)用,所以需要重新進(jìn)行初始化。
練習(xí)
1.如果存儲(chǔ)過(guò)程的參數(shù)類型為OUT,那么調(diào)用時(shí)傳遞的參數(shù)應(yīng)該為:
     A.常量 B.表達(dá)式                C.變量 D.都可以
2.下列有關(guān)存儲(chǔ)過(guò)程的特點(diǎn)說(shuō)法錯(cuò)誤的是:
     A.存儲(chǔ)過(guò)程不能將值傳回調(diào)用的主程序
     B.存儲(chǔ)過(guò)程是一個(gè)命名的模塊
     C.編譯的存儲(chǔ)過(guò)程存放在數(shù)據(jù)庫(kù)中
     D.一個(gè)存儲(chǔ)過(guò)程可以調(diào)用另一個(gè)存儲(chǔ)過(guò)程
3.下列有關(guān)函數(shù)的特點(diǎn)說(shuō)法錯(cuò)誤的是:
     A.函數(shù)必須定義返回類型
     B.函數(shù)參數(shù)的類型只能是IN
     C.在函數(shù)體內(nèi)可以多次使用RETURN語(yǔ)句
     D.函數(shù)的調(diào)用應(yīng)使用EXECUTE命令
4.包中不能包含的元素為:
     A.存儲(chǔ)過(guò)程 B.存儲(chǔ)函數(shù)
     C.游標(biāo)    D.表
5.下列有關(guān)包的使用說(shuō)法錯(cuò)誤的是:
     A.在不同的包內(nèi)模塊可以重名
     B.包的私有過(guò)程不能被外部程序調(diào)用
     C.包體中的過(guò)程和函數(shù)必須在包頭部分說(shuō)明
     D.必須先創(chuàng)建包頭,然后創(chuàng)建包體

相關(guān)文章

  • 分析Oracle生成Statpack步驟

    分析Oracle生成Statpack步驟

    本文將介紹ORACLE配置STATSPACK步驟,需要了解更多的朋友可以參考下
    2012-11-11
  • 限制ip訪問(wèn)Oracle數(shù)據(jù)庫(kù)的方法步驟

    限制ip訪問(wèn)Oracle數(shù)據(jù)庫(kù)的方法步驟

    這篇文章主要給大家介紹了關(guān)于限制ip訪問(wèn)Oracle數(shù)據(jù)庫(kù)的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者使用Oracle數(shù)據(jù)庫(kù)具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT)

    Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT)

    這篇文章主要介紹了Oracle 遍歷游標(biāo)的四種方式匯總(for、fetch、while、BULK COLLECT),幫助大家更好的理解和使用Oracle數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-10-10
  • oracle的歸檔模式 ORACLE數(shù)據(jù)庫(kù)歸檔日志常用命令

    oracle的歸檔模式 ORACLE數(shù)據(jù)庫(kù)歸檔日志常用命令

    Oracle數(shù)據(jù)庫(kù)有聯(lián)機(jī)重做日志,這個(gè)日志是記錄對(duì)數(shù)據(jù)庫(kù)所做的修改,比如插入,刪除,更新數(shù)據(jù)等,對(duì)這些操作都會(huì)記錄在聯(lián)機(jī)重做日志里
    2013-01-01
  • Oracle數(shù)據(jù)庫(kù)如何切換登錄用戶(system和sys)

    Oracle數(shù)據(jù)庫(kù)如何切換登錄用戶(system和sys)

    文章介紹了如何使用SQL*Plus工具登錄Oracle數(shù)據(jù)庫(kù)的system用戶,包括打開(kāi)登錄入口、輸入用戶名和口令、以及切換到sys用戶的方法,總結(jié)部分鼓勵(lì)讀者參考并支持腳本之家
    2025-02-02
  • Oracle 數(shù)據(jù)庫(kù)自動(dòng)存儲(chǔ)管理-安裝配置

    Oracle 數(shù)據(jù)庫(kù)自動(dòng)存儲(chǔ)管理-安裝配置

    關(guān)于ASM的討論很多,但是到底什么是ASM?ASM是一個(gè)有效的抽象層,使你的Oracle數(shù)據(jù)庫(kù)可以與叫做diskgroups的抽象空間一起使用,而不是直接使用datafiles。
    2009-05-05
  • Windows系統(tǒng)下Oracle?11g完全卸載教程(推薦!)

    Windows系統(tǒng)下Oracle?11g完全卸載教程(推薦!)

    安裝軟件是首要,雖然不是特別重要,但是錯(cuò)誤的安裝也是相當(dāng)費(fèi)勁和抓狂的,所以這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下Oracle?11g完全卸載的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),要的朋友可以參考下
    2024-06-06
  • ip修改后orcale服務(wù)無(wú)法啟動(dòng)問(wèn)題解決

    ip修改后orcale服務(wù)無(wú)法啟動(dòng)問(wèn)題解決

    今天配置虛擬機(jī)中設(shè)計(jì)了下ip,使虛擬機(jī)和主機(jī)處在同一網(wǎng)段,然后使用webservice就成功了就來(lái)了,oracle連接不上了,接下來(lái)講提供詳細(xì)的解決方法
    2012-11-11
  • Oracle中pivot函數(shù)圖文實(shí)例詳解

    Oracle中pivot函數(shù)圖文實(shí)例詳解

    pivot操作是一種數(shù)據(jù)處理方法,可以將一個(gè)表中的行數(shù)據(jù)轉(zhuǎn)換為列數(shù)據(jù),這種轉(zhuǎn)換對(duì)于表格數(shù)據(jù)的分析和展示非常有用,下面這篇文章主要給大家介紹了關(guān)于Oracle中pivot函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • Oracle數(shù)據(jù)遠(yuǎn)程連接的四種設(shè)置方法和注意事項(xiàng)

    Oracle數(shù)據(jù)遠(yuǎn)程連接的四種設(shè)置方法和注意事項(xiàng)

    Oracle數(shù)據(jù)庫(kù)的遠(yuǎn)程連接可以通過(guò)多種方式來(lái)實(shí)現(xiàn),本文我們主要介紹四種遠(yuǎn)程連接的方法和注意事項(xiàng),并通過(guò)示例來(lái)說(shuō)明,接下來(lái)我們就開(kāi)始介紹
    2014-04-04

最新評(píng)論

99热这里只有国产精品6| 天天躁夜夜躁日日躁a麻豆| 久久久久91精品推荐99| 天天日天天干天天舔天天射| 日日夜夜精品一二三| 夫妻在线观看视频91| 日本黄在免费看视频| 做爰视频毛片下载蜜桃视频1| 亚洲激情,偷拍视频| 天天爽夜夜爽人人爽QC| 绝色少妇高潮3在线观看| 换爱交换乱高清大片| 国产高清97在线观看视频| 久碰精品少妇中文字幕av| 亚洲午夜电影之麻豆| 毛片av在线免费看| 久久久久久久一区二区三| 在线观看黄色成年人网站| 五十路丰满人妻熟妇| 亚洲成人av一区在线| 2020国产在线不卡视频| 欧美香蕉人妻精品一区二区| 青青热久免费精品视频在线观看| 人妻少妇亚洲精品中文字幕| 成年人该看的视频黄免费| 日本人妻少妇18—xx| 97国产在线观看高清| 亚洲精品亚洲人成在线导航| 国产欧美精品不卡在线| 久久久久久99国产精品| av在线观看网址av| 亚洲av日韩精品久久久久久hd| 免费人成黄页网站在线观看国产| 日韩精品电影亚洲一区| 青青青青在线视频免费观看| 中文 成人 在线 视频| 天天日天天添天天爽| 亚洲国产精品黑丝美女| 日本裸体熟妇区二区欧美| 国产美女精品福利在线| 亚洲av无硬久久精品蜜桃| 亚洲精品乱码久久久本| 天堂av中文在线最新版| 最新国产精品网址在线观看| 国产麻豆乱子伦午夜视频观看| 91精品啪在线免费| 婷婷久久久久深爱网| 日本最新一二三区不卡在线| 亚洲图片偷拍自拍区| 黄片三级三级三级在线观看| 在线播放一区二区三区Av无码| 青青青青草手机在线视频免费看| 久久精品视频一区二区三区四区 | 亚洲av成人免费网站| 日韩特级黄片高清在线看| 亚洲一区久久免费视频| 天天色天天爱天天爽| 18禁美女无遮挡免费| 亚洲精品国产久久久久久| 日本熟妇一区二区x x| 亚洲图片偷拍自拍区| 人人妻人人爽人人添夜| 在线免费观看黄页视频| 青青青国产片免费观看视频| 天天操天天干天天艹| av在线shipin| 在线视频精品你懂的| 欧美黑人与人妻精品| 国产九色91在线视频| 免费国产性生活视频| 一区二区三区四区视频| 91老师蜜桃臀大屁股| av在线免费观看亚洲天堂| 欧美中国日韩久久精品| 国产高清精品极品美女| 中文字幕+中文字幕| 亚洲国际青青操综合网站| 亚洲成av人无码不卡影片一| 五月天中文字幕内射| 99久久超碰人妻国产| 亚洲国产精品中文字幕网站| 91she九色精品国产| 欧美视频中文一区二区三区| 亚洲va天堂va国产va久| 天天日天天干天天要| 午夜影院在线观看视频羞羞羞| av一区二区三区人妻| 亚洲综合色在线免费观看| 国产一区自拍黄视频免费观看| 国产97视频在线精品| 亚洲午夜高清在线观看| 在线观看视频网站麻豆| 日本人妻精品久久久久久| 亚洲高清国产自产av| 国产福利小视频大全| 日韩美女搞黄视频免费| 精品国产在线手机在线| 青青操免费日综合视频观看| 亚洲2021av天堂| 欧美日韩v中文在线| 日本福利午夜电影在线观看| 五十路熟女av天堂| 亚洲 中文字幕在线 日韩| 激情五月婷婷综合色啪| 熟女人妻在线中出观看完整版 | 青青青aaaa免费| 521精品视频在线观看| 午夜毛片不卡在线看| 亚洲欧美自拍另类图片| 亚洲一区av中文字幕在线观看| 天天夜天天日天天日| 57pao国产一区二区| 在线免费91激情四射 | 55夜色66夜色国产精品站| 一区二区三区毛片国产一区| 2022国产精品视频| 亚洲激情,偷拍视频| 天天日天天干天天搡| 一区二区三区精品日本| 国产夫妻视频在线观看免费| 92福利视频午夜1000看| 最新91精品视频在线| 一区二区三区蜜臀在线| 18禁美女无遮挡免费| 国产男女视频在线播放| jiuse91九色视频| 99婷婷在线观看视频| 国产精品三级三级三级| 直接能看的国产av| 亚洲成人情色电影在线观看| 国产麻豆91在线视频| 日韩无码国产精品强奸乱伦| 久草电影免费在线观看| 97欧洲一区二区精品免费| 国产精品人妻66p| 免费观看国产综合视频| 日本特级片中文字幕| 无忧传媒在线观看视频| 亚洲欧美自拍另类图片| 伊人情人综合成人久久网小说| 精品久久久久久久久久中文蒉 | 日本在线不卡免费视频| weyvv5国产成人精品的视频| 四川五十路熟女av| 大鸡吧插入女阴道黄色片| 天天操天天干天天艹| 青青青aaaa免费| 在线免费观看日本伦理| 三级等保密码要求条款| 2019av在线视频| 自拍偷拍亚洲另类色图| 最新欧美一二三视频| 欧美精品中文字幕久久二区| 国产在线一区二区三区麻酥酥| 欧美精品中文字幕久久二区| 成人av中文字幕一区| 一区二区三区 自拍偷拍| 任我爽精品视频在线播放| 人妻av无码专区久久绿巨人| 春色激情网欧美成人| 风流唐伯虎电视剧在线观看 | 激情伦理欧美日韩中文字幕| 丝袜长腿第一页在线| 欧美精品资源在线观看| 日韩美女精品视频在线观看网站 | 亚洲女人的天堂av| 国产精品伦理片一区二区| 大鸡巴操娇小玲珑的女孩逼| 视频 国产 精品 熟女 | 中文字母永久播放1区2区3区 | 91免费观看在线网站| 国产精品一区二区三区蜜臀av | 中文字幕高清资源站| 亚洲图片欧美校园春色| 黄色av网站免费在线| 51精品视频免费在线观看| 国产乱子伦精品视频潮优女| 日本脱亚入欧是指什么| 一区二区三区四区视频| 成年人的在线免费视频| 久草视频在线看免费| 视频一区 二区 三区 综合| 毛片av在线免费看| 国产在线自在拍91国语自产精品| 91啪国自产中文字幕在线| 亚洲1区2区3区精华液| 亚洲av一妻不如妾| 亚洲综合乱码一区二区| 亚洲国产中文字幕啊啊啊不行了 | 999久久久久999| 99热久久这里只有精品| 性欧美日本大妈母与子| 91高清成人在线视频| 40道精品招牌菜特色| 成人午夜电影在线观看 久久| 国产片免费观看在线观看| 精品区一区二区三区四区人妻 | 日本少妇精品免费视频| 1024久久国产精品| 黑人借宿ntr人妻的沦陷2| 任你操任你干精品在线视频| 一二三中文乱码亚洲乱码one| 日本av在线一区二区三区| 国产高潮无码喷水AV片在线观看| 青青青aaaa免费| 亚洲精品ww久久久久久| 天天操天天污天天射| 国产福利在线视频一区| 老鸭窝日韩精品视频观看| 午夜婷婷在线观看视频| 天天日天天玩天天摸| 亚洲国产成人在线一区| 亚洲综合乱码一区二区| 精品美女在线观看视频在线观看| 青青尤物在线观看视频网站| 国产视频网站一区二区三区| 国产av国片精品一区二区| 最新中文字幕免费视频| 边摸边做超爽毛片18禁色戒| 天天插天天色天天日| 日日操夜夜撸天天干| 久久丁香婷婷六月天| 亚洲卡1卡2卡三卡四老狼| 色天天天天射天天舔| 亚洲无码一区在线影院| 中国老熟女偷拍第一页| 五十路熟女av天堂| 亚洲成人激情视频免费观看了 | 大胸性感美女羞爽操逼毛片| 亚洲粉嫩av一区二区三区| 骚逼被大屌狂草视频免费看| 天天日天天爽天天爽| 好吊操视频这里只有精品| 中文字幕在线免费第一页| 国产av福利网址大全| 天堂va蜜桃一区入口| 国产精品三级三级三级| 婷婷六月天中文字幕| 欧洲欧美日韩国产在线| 中文字幕最新久久久| 国产三级影院在线观看| 果冻传媒av一区二区三区| 超级福利视频在线观看| 风流唐伯虎电视剧在线观看| 成人亚洲精品国产精品| 国产乱弄免费视频观看| 91高清成人在线视频| 日本性感美女写真视频| 亚洲激情偷拍一区二区| 亚洲专区激情在线观看视频| 特大黑人巨大xxxx| 天天操天天爽天天干| 青青青青青手机视频| 91色秘乱一区二区三区| 青青青青草手机在线视频免费看| 欧美亚洲牲夜夜综合久久| 欧美色婷婷综合在线| 天天艹天天干天天操| 青青草在观免费国产精品| 男人天堂av天天操| 99热这里只有国产精品6| 大香蕉伊人国产在线| 精品久久久久久久久久久久人妻| 国产1区,2区,3区| 中文字幕网站你懂的| 日本人妻少妇18—xx| 中国视频一区二区三区| 国产V亚洲V天堂无码欠欠| 亚洲第一黄色在线观看| 天天射,天天操,天天说| 国产真实乱子伦a视频 | 青青色国产视频在线| 天天干夜夜操天天舔| 端庄人妻堕落挣扎沉沦| 国产精品久久综合久久| 66久久久久久久久久久| 免费大片在线观看视频网站| 性感美女诱惑福利视频| 亚洲成人激情视频免费观看了| 日本xx片在线观看| 色97视频在线播放| 日韩精品激情在线观看| 66久久久久久久久久久| 女蜜桃臀紧身瑜伽裤| 中文字幕人妻av在线观看| 99re6热在线精品| 美女福利视频导航网站| 午夜精品福利91av| 久久午夜夜伦痒痒想咳嗽P| 在线免费观看亚洲精品电影| 成人av在线资源网站| 国产成人精品福利短视频| 无套猛戳丰满少妇人妻| 亚洲美女高潮喷浆视频| 在线新三级黄伊人网| 国产日本欧美亚洲精品视| 亚洲国产免费av一区二区三区 | 亚洲成人国产综合一区| www久久久久久久久久久| 午夜精品一区二区三区更新| 又色又爽又黄的美女裸体| 亚洲 清纯 国产com| 福利一二三在线视频观看| 国产自拍在线观看成人| 成熟丰满熟妇高潮xx×xx| 精品一区二区亚洲欧美| 亚洲成人激情av在线| 9国产精品久久久久老师| 中文字幕网站你懂的| 不戴胸罩引我诱的隔壁的人妻| 人人妻人人爽人人澡人人精品| 家庭女教师中文字幕在线播放| 在线视频免费观看网| 三级黄色亚洲成人av| 69精品视频一区二区在线观看| 亚洲av日韩av网站| 国产实拍勾搭女技师av在线| 91精品国产91久久自产久强| 一区二区三区 自拍偷拍| 宅男噜噜噜666国产| 一本久久精品一区二区| av在线免费观看亚洲天堂| 亚洲熟妇无码一区二区三区| 欧美一区二区三区啪啪同性| 黑人巨大的吊bdsm| 成人av电影免费版| 日韩欧美国产一区ab| tube69日本少妇| 亚洲天堂第一页中文字幕| 成人免费毛片aaaa| 2022国产精品视频| 日本女人一级免费片| 午夜精品久久久久麻豆影视| 亚洲另类在线免费观看| 激情啪啪啪啪一区二区三区| 蜜桃臀av蜜桃臀av| 99热久久这里只有精品8| 国产精品久久9999| 91精品综合久久久久3d动漫| 人妻最新视频在线免费观看| 97超碰国语国产97超碰| 国产亚州色婷婷久久99精品| 亚洲成人免费看电影| 97人妻人人澡爽人人精品| 日韩成人免费电影二区| 快点插进来操我逼啊视频| 亚洲av黄色在线网站| caoporn蜜桃视频| 久久精品国产亚洲精品166m| 在线观看av亚洲情色| 在线观看国产网站资源| 五色婷婷综合狠狠爱| 日韩av免费观看一区| 激情啪啪啪啪一区二区三区| 亚洲国产欧美一区二区三区久久 | 亚洲中文精品人人免费| 亚洲最大黄 嗯色 操 啊| 国产普通话插插视频| 熟女人妻在线中出观看完整版| 少妇深喉口爆吞精韩国| 97瑟瑟超碰在线香蕉| 欧美一区二区三区久久久aaa| 亚洲一区二区人妻av| 亚洲精品麻豆免费在线观看| 任你操任你干精品在线视频| 一区二区三区国产精选在线播放| free性日本少妇| 欧美女同性恋免费a| 亚洲va国产va欧美va在线| 日韩欧美制服诱惑一区在线| 亚洲av无硬久久精品蜜桃| 噜噜色噜噜噜久色超碰| 欧美中国日韩久久精品| 人人妻人人人操人人人爽| 日韩欧美国产一区不卡| av森泽佳奈在线观看| tube69日本少妇| 黑人变态深video特大巨大| 无码中文字幕波多野不卡| 亚洲天堂第一页中文字幕| 九色视频在线观看免费| 97国产福利小视频合集| 成年人的在线免费视频| 特级欧美插插插插插bbbbb| 国产一区二区三免费视频| 午夜激情久久不卡一区二区| 91麻豆精品秘密入口在线观看| 伊人情人综合成人久久网小说| 国产视频网站一区二区三区| 做爰视频毛片下载蜜桃视频1| 亚洲精品亚洲人成在线导航| 蜜桃精品久久久一区二区| 熟女少妇激情五十路| 国产精品人妻熟女毛片av久| 少妇高潮无套内谢麻豆| 国产日韩欧美美利坚蜜臀懂色| 国产熟妇人妻ⅹxxxx麻豆| 美味人妻2在线播放| 亚洲少妇高潮免费观看| 在线国产中文字幕视频| 精品成人啪啪18免费蜜臀| 在线免费观看99视频| 午夜精彩视频免费一区| 阿v天堂2014 一区亚洲| 丝袜肉丝一区二区三区四区在线| 欧美精品欧美极品欧美视频| 免费在线观看污污视频网站| 日本五十路熟新垣里子| 天天干天天操天天扣| 成人av中文字幕一区| 大香蕉玖玖一区2区| 最后99天全集在线观看| 天天日天天敢天天干| 亚洲最大黄 嗯色 操 啊| 青青青青青操视频在线观看| 中文亚洲欧美日韩无线码| 97少妇精品在线观看| 日本午夜福利免费视频| 美女日逼视频免费观看| 亚洲av成人免费网站| 成人sm视频在线观看| 国产亚洲欧美视频网站| 91亚洲手机在线视频播放| 亚洲精品久久综合久| 精品久久久久久久久久久a√国产| 亚洲 中文 自拍 另类 欧美| 欧美在线精品一区二区三区视频 | 亚国产成人精品久久久| 亚洲av黄色在线网站| 激情人妻校园春色亚洲欧美 | 91精品免费久久久久久| 精品91自产拍在线观看一区| 99视频精品全部15| 美女av色播在线播放| 国产又粗又猛又爽又黄的视频在线| 亚洲精品无码色午夜福利理论片| 国产91久久精品一区二区字幕| 亚洲 中文字幕在线 日韩| 看一级特黄a大片日本片黑人| 国产女人露脸高潮对白视频| 在线观看黄色成年人网站| 抽查舔水白紧大视频| 91精品国产综合久久久蜜 | 99精品视频之69精品视频| 日韩欧美中文国产在线 | 成人国产小视频在线观看| 天天操天天插天天色| 欧美va亚洲va天堂va| 五十路熟女av天堂| 亚洲天堂av最新网址| 97成人免费在线观看网站| 日本三极片中文字幕| 欧美怡红院视频在线观看| 免费看国产又粗又猛又爽又黄视频| 亚洲精品高清自拍av| 日本韩国亚洲综合日韩欧美国产 | 80电影天堂网官网| 亚洲国产欧美国产综合在线| 91人妻精品一区二区在线看 | 亚洲色偷偷综合亚洲AV伊人| 久草视频首页在线观看| 经典av尤物一区二区| 中文字幕亚洲中文字幕| 久久精品国产999| 欧美成人综合色在线噜噜| 欧美少妇性一区二区三区| 日韩亚国产欧美三级涩爱| 一区二区三区麻豆福利视频| 国产精品一区二区久久久av| 韩国女主播精品视频网站| 亚洲精品中文字幕下载| 欧美在线精品一区二区三区视频| 久久机热/这里只有| 中文字幕亚洲久久久| 国产综合高清在线观看| 国产欧美精品不卡在线| 69精品视频一区二区在线观看| 中国黄色av一级片| 一本一本久久a久久精品综合不卡| 91精品国产91久久自产久强| 美女视频福利免费看| 国产精品sm调教视频| 日本又色又爽又黄又粗| 中文字幕一区二区三区人妻大片 | 国产乱弄免费视频观看| 五十路在线观看完整版| 日韩人妻在线视频免费| 免费手机黄页网址大全| 五月天中文字幕内射| 亚洲变态另类色图天堂网| 自拍偷拍日韩欧美亚洲| 男人的天堂av日韩亚洲| 久久美欧人妻少妇一区二区三区| 中文字幕 人妻精品| 自拍偷拍日韩欧美亚洲| 亚洲欧美成人综合视频| 亚洲最大黄了色网站| 国产欧美精品不卡在线| 成年人免费看在线视频| 熟女人妻三十路四十路人妻斩| 高清一区二区欧美系列 | 国产视频网站一区二区三区| 精品久久久久久久久久久99| 国产午夜男女爽爽爽爽爽视频 | 亚洲国产精品黑丝美女| 国产精品久久9999| 老司机深夜免费福利视频在线观看| 在线免费观看视频一二区| 亚洲中文精品人人免费| 亚洲激情唯美亚洲激情图片| 国内精品在线播放第一页| 亚洲国产第一页在线观看| gogo国模私拍视频| 亚洲国产成人在线一区| 天天通天天透天天插| 日本性感美女视频网站| 超级av免费观看一区二区三区| 欧美成人一二三在线网| 亚洲最大黄了色网站| 超级福利视频在线观看| 中文亚洲欧美日韩无线码| 最新中文字幕乱码在线| 日本人妻少妇18—xx| 小穴多水久久精品免费看| 啪啪啪啪啪啪啪啪啪啪黄色| 欧美成人综合视频一区二区| 国产激情av网站在线观看| 韩国AV无码不卡在线播放| 免费无毒热热热热热热久| 日韩精品二区一区久久| 亚洲av无码成人精品区辽| 欧美日韩高清午夜蜜桃大香蕉| 加勒比视频在线免费观看| 亚洲成a人片777777| 日韩中文字幕精品淫| jiujiure精品视频在线| 护士特殊服务久久久久久久| 亚洲成人三级在线播放| 国产大学生援交正在播放| 国产精品成人xxxx| 美女福利写真在线观看视频| 久久久久只精品国产三级| 精品国产在线手机在线| 亚洲国产精品久久久久久6| 操的小逼流水的文章| 5528327男人天堂| 无码精品一区二区三区人| 国产亚洲欧美45p| 天天干天天搞天天摸| 久久久久久9999久久久久| 亚洲欧美成人综合在线观看| 1区2区3区不卡视频| 久久这里只有精品热视频| 天天草天天色天天干| 久久精品国产23696| 午夜福利资源综合激情午夜福利资 | 熟女在线视频一区二区三区| 中文字幕免费在线免费| 国产普通话插插视频| 亚洲成人三级在线播放 | 国产黄色片在线收看| 日韩不卡中文在线视频网站| 免费看国产又粗又猛又爽又黄视频| 国产精品入口麻豆啊啊啊| 一区二区三区麻豆福利视频| 亚洲 国产 成人 在线| 99久久久无码国产精品性出奶水| 宅男噜噜噜666国产| 91国产在线视频免费观看| 国产精品自拍偷拍a| 国产黑丝高跟鞋视频在线播放 | 亚洲av无码成人精品区辽| 国产精品成久久久久三级蜜臀av| 9色精品视频在线观看| 最新国产亚洲精品中文在线| 丝袜美腿欧美另类 中文字幕| 天堂av在线官网中文| 狠狠的往里顶撞h百合| 免费一级特黄特色大片在线观看| 黄色录像鸡巴插进去| 天天干夜夜操天天舔| 女生自摸在线观看一区二区三区 | 成年人黄色片免费网站| 国产亚州色婷婷久久99精品| 国产亚洲欧美另类在线观看| 黄页网视频在线免费观看| 五月色婷婷综合开心网4438| gav成人免费播放| 亚洲中文字幕综合小综合| 日本熟妇丰满厨房55| 色偷偷伊人大杳蕉综合网 | 偷拍自拍视频图片免费| 婷婷久久久综合中文字幕| 亚洲免费在线视频网站| 亚洲av在线观看尤物| 五十路息与子猛烈交尾视频 | 不卡精品视频在线观看| 91精品激情五月婷婷在线| 欧美一区二区三区在线资源| 国产精品黄片免费在线观看| 美女av色播在线播放| 污污小视频91在线观看| 亚洲福利天堂久久久久久 | 视频久久久久久久人妻| 天天日天天天天天天天天天天| 东京热男人的av天堂| 日韩欧美一级黄片亚洲| 综合激情网激情五月天| 日本韩国在线观看一区二区| 真实国产乱子伦一区二区| 99久久中文字幕一本人| 40道精品招牌菜特色| 大鸡巴操b视频在线| 亚洲成人午夜电影在线观看| 女同性ⅹxx女同hd| 亚洲av在线观看尤物| 91桃色成人网络在线观看| 亚洲一区二区三区久久受| 一区二区三区 自拍偷拍| 国产精品视频资源在线播放| 99久久成人日韩欧美精品| 喷水视频在线观看这里只有精品| 最新国产精品网址在线观看| heyzo蜜桃熟女人妻| 日韩特级黄片高清在线看| 国产普通话插插视频| 18禁网站一区二区三区四区| 91av精品视频在线| 色伦色伦777国产精品| 99精品免费久久久久久久久a| 午夜免费体验区在线观看| 视频一区 视频二区 视频| 免费观看成年人视频在线观看| 91欧美在线免费观看| 亚洲欧美激情国产综合久久久| 韩国亚洲欧美超一级在线播放视频| 熟女俱乐部一二三区| 天天操夜夜操天天操天天操| 国产欧美精品不卡在线| 男女第一次视频在线观看| 边摸边做超爽毛片18禁色戒| 亚洲变态另类色图天堂网| 国产精品人妻66p| 亚洲伊人av天堂有码在线| 91快播视频在线观看| 在线亚洲天堂色播av电影| 午夜场射精嗯嗯啊啊视频| 丝袜美腿视频诱惑亚洲无| 国产女人叫床高潮大片视频| 国产黄网站在线观看播放| 阿v天堂2014 一区亚洲| 亚洲综合在线视频可播放| 日本欧美视频在线观看三区| 大鸡八强奸视频在线观看| 午夜影院在线观看视频羞羞羞| 国产在线观看免费人成短视频| 日韩人妻丝袜中文字幕| 天天做天天干天天舔| 高清成人av一区三区| 91九色porny国产蝌蚪视频| 污污小视频91在线观看| 中文字幕 人妻精品| 久草视频在线一区二区三区资源站| 五十路熟女人妻一区二区9933| 日本女大学生的黄色小视频| 在线观看的黄色免费网站| 美女福利视频导航网站| 强行扒开双腿猛烈进入免费版| 精品视频中文字幕在线播放 | 国产精品自偷自拍啪啪啪| 日比视频老公慢点好舒服啊| 青青草原网站在线观看| 国产精品人妻一区二区三区网站| 亚洲天堂精品久久久| 午夜久久久久久久精品熟女| 521精品视频在线观看| 国产日韩欧美视频在线导航| 操的小逼流水的文章| 国产精品久久综合久久| 亚洲在线一区二区欧美| 换爱交换乱高清大片| 最新的中文字幕 亚洲| 亚洲av日韩精品久久久久久hd| 中文字幕日本人妻中出| 欧美精品欧美极品欧美视频| 不卡一不卡二不卡三| 亚洲激情唯美亚洲激情图片| 97少妇精品在线观看| 九色porny九色9l自拍视频| 老司机福利精品免费视频一区二区| 蜜桃久久久久久久人妻| 亚洲欧美另类自拍偷拍色图| 国产一区二区在线欧美| 亚洲综合另类精品小说| 欧美乱妇无乱码一区二区| 直接观看免费黄网站| 欧美日韩人妻久久精品高清国产| 青青青青在线视频免费观看| 青青草视频手机免费在线观看| 自拍偷拍日韩欧美一区二区| 日韩近亲视频在线观看| 九一传媒制片厂视频在线免费观看| 精产国品久久一二三产区区别| 可以免费看的www视频你懂的| 成熟熟女国产精品一区| 国产精品久久久黄网站| 99久久99一区二区三区| 狠狠的往里顶撞h百合| 精品久久久久久久久久久久人妻| 欧美视频中文一区二区三区| 日视频免费在线观看| 久草视频首页在线观看| 亚洲成人国产综合一区| 亚洲午夜高清在线观看| 中文字幕一区二区三区人妻大片| 日日操综合成人av| 中字幕人妻熟女人妻a62v网| 久久久91蜜桃精品ad| 天天做天天干天天操天天射| 在线观看日韩激情视频| 只有精品亚洲视频在线观看| 天天干天天操天天爽天天摸| 日韩加勒比东京热二区| av视网站在线观看| 亚洲综合图片20p| 91麻豆精品91久久久久同性| 日韩精品一区二区三区在线播放| 水蜜桃国产一区二区三区| 日韩欧美在线观看不卡一区二区 | 日本在线一区二区不卡视频| 北条麻妃av在线免费观看| 偷拍美女一区二区三区| 人妻熟女在线一区二区| 999久久久久999| 大鸡吧插入女阴道黄色片| 国产精品国产三级国产午| 日韩美在线观看视频黄| 国产精品女邻居小骚货| 精品久久婷婷免费视频| 无码精品一区二区三区人 | 天天摸天天干天天操科普| 欧美日本在线观看一区二区| www,久久久,com| 国产欧美精品一区二区高清 | 国产亚洲精品欧洲在线观看| 91精品国产观看免费| 日本福利午夜电影在线观看| 五十路熟女人妻一区二| 亚洲av无硬久久精品蜜桃| 亚洲精品色在线观看视频| 国产一区二区视频观看| 日日日日日日日日夜夜夜夜夜夜| 国产九色91在线视频| 中文字幕av男人天堂| 精品91高清在线观看| 中文字幕,亚洲人妻| 久久久久五月天丁香社区| 天天躁夜夜躁日日躁a麻豆| 水蜜桃国产一区二区三区| 在线观看免费岛国av| 国产九色91在线视频| 国产精品久久久久久久女人18| 熟女91pooyn熟女| 久久www免费人成一看片| 在线观看的黄色免费网站| 视频啪啪啪免费观看| 亚洲中文字幕人妻一区| 青青青青青青青青青青草青青| 亚洲国产最大av综合| 搡老妇人老女人老熟女| 97人妻无码AV碰碰视频| 在线视频国产欧美日韩| 亚洲av日韩精品久久久| 亚洲午夜福利中文乱码字幕| 亚洲免费av在线视频| 久久机热/这里只有| 午夜在线观看一区视频| 久草电影免费在线观看| 国产日韩欧美视频在线导航| 亚洲区美熟妇久久久久| 亚洲成人精品女人久久久| 日本后入视频在线观看| 国产91精品拍在线观看| 大鸡巴操娇小玲珑的女孩逼| 天天干天天啪天天舔| 91人妻人人做人人爽在线| 91国语爽死我了不卡| 精品国产成人亚洲午夜| 加勒比视频在线免费观看| 亚洲推理片免费看网站| 亚洲成人激情av在线| 国内资源最丰富的网站| 午夜精品福利一区二区三区p | 亚洲另类伦春色综合小| 青青青青操在线观看免费| 日韩伦理短片在线观看| 在线 中文字幕 一区| 被大鸡吧操的好舒服视频免费| 欧美精产国品一二三产品区别大吗| 93精品视频在线观看| 97精品成人一区二区三区| 91免费观看在线网站| 黄色的网站在线免费看| 日韩熟女系列一区二区三区| 欧美少妇性一区二区三区| 伊人日日日草夜夜草| 久草视频在线看免费| 91国内精品自线在拍白富美| 亚洲av无码成人精品区辽| 国产成人精品一区在线观看 | av久久精品北条麻妃av观看| 欧美爆乳肉感大码在线观看| 久青青草视频手机在线免费观看 | 成人亚洲国产综合精品| 久碰精品少妇中文字幕av| 亚洲一级美女啪啪啪| 国产妇女自拍区在线观看| 久久热久久视频在线观看| 成人综合亚洲欧美一区 | 91精品国产综合久久久蜜| 日本性感美女视频网站| 偷拍自拍福利视频在线观看| 特级无码毛片免费视频播放| 成人乱码一区二区三区av| 一个人免费在线观看ww视频| 日韩三级电影华丽的外出| 午夜大尺度无码福利视频| 自拍偷拍亚洲欧美在线视频| 欧美偷拍亚洲一区二区| 香港三日本三韩国三欧美三级| 亚洲一区二区三区久久午夜 | 国产成人精品av网站| 3344免费偷拍视频| 日本一区精品视频在线观看| 欲乱人妻少妇在线视频裸| aⅴ五十路av熟女中出| 国产真实灌醉下药美女av福利| 天天干天天啪天天舔| 黄色三级网站免费下载| 中文字幕人妻三级在线观看| 阴茎插到阴道里面的视频| 色综合天天综合网国产成人| 男女之间激情网午夜在线| 无码日韩人妻精品久久| 男人在床上插女人视频| 2021天天色天天干| 欧美乱妇无乱码一区二区| 亚洲av成人免费网站| 在线视频免费观看网| 欲乱人妻少妇在线视频裸| 在线免费观看av日韩| 日韩欧美高清免费在线| 深夜男人福利在线观看| 亚洲麻豆一区二区三区| 国产精品午夜国产小视频| 熟女人妻在线中出观看完整版| 欧美黑人性暴力猛交喷水| 偷拍3456eee| 国产精品一区二区久久久av| 曰本无码人妻丰满熟妇啪啪| 国产女人被做到高潮免费视频| 狠狠躁夜夜躁人人爽天天久天啪| 91精品激情五月婷婷在线| 久久久精品欧洲亚洲av| 人妻少妇一区二区三区蜜桃| 亚洲国产在人线放午夜| 天天色天天舔天天射天天爽| 综合页自拍视频在线播放| 欧美日本在线观看一区二区| 中文亚洲欧美日韩无线码| 日韩人妻丝袜中文字幕| 亚洲另类综合一区小说| 亚洲图片欧美校园春色| 中文字幕日韩精品就在这里| 国产精品手机在线看片| 91麻豆精品传媒国产黄色片| 沈阳熟妇28厘米大战黑人| 天天干天天操天天爽天天摸 | 精品国产乱码一区二区三区乱| 婷婷六月天中文字幕| 国产在线一区二区三区麻酥酥| 五月激情婷婷久久综合网| 精品老妇女久久9g国产| 日本三极片中文字幕| av资源中文字幕在线观看| 成人资源在线观看免费官网| 黑人解禁人妻叶爱071| 国产午夜亚洲精品不卡在线观看| 久久精品亚洲成在人线a| 嫩草aⅴ一区二区三区| 欧美视频不卡一区四区| 天天干天天日天天谢综合156| 青青擦在线视频国产在线| av无限看熟女人妻另类av| 在线观看操大逼视频| xxx日本hd高清| 亚洲一区二区三区av网站| 天天摸天天日天天操| 日本熟妇一区二区x x| 成人在线欧美日韩国产| 成人av免费不卡在线观看| 91精品国产观看免费| 一级黄片大鸡巴插入美女| 欧美日本在线观看一区二区| 老熟妇xxxhd老熟女| 日日操夜夜撸天天干| 国产成人精品亚洲男人的天堂| 红桃av成人在线观看| 欧美视频中文一区二区三区| av在线免费中文字幕| 日本人竟这样玩学生妹| 欧美 亚洲 另类综合| 懂色av蜜桃a v| 日本18禁久久久久久| 黄工厂精品视频在线观看| 在线不卡成人黄色精品| 欧美一区二区三区高清不卡tv| 巨乳人妻日下部加奈被邻居中出| 欧美日本在线观看一区二区 | 天天爽夜夜爽人人爽QC| 91免费放福利在线观看| 中文字幕在线观看国产片| 免费高清自慰一区二区三区网站| 最近的中文字幕在线mv视频| 亚洲精品中文字幕下载| 狠狠嗨日韩综合久久| 亚洲在线免费h观看网站| 在线观看的a站 最新| 国产精品三级三级三级| 欧美色婷婷综合在线| 黑人巨大的吊bdsm| 少妇人妻久久久久视频黄片| 超碰在线中文字幕一区二区| 日韩a级黄色小视频| 4个黑人操素人视频网站精品91| 一区二区三区精品日本| 久久久久久久久久一区二区三区 | 综合国产成人在线观看| 中文字幕1卡1区2区3区| 中文字幕人妻熟女在线电影| 直接观看免费黄网站| 把腿张开让我插进去视频| 女同互舔一区二区三区| 一色桃子久久精品亚洲| 又粗又硬又猛又爽又黄的| 天天日天天干天天要| 男人天堂av天天操| 色综合天天综合网国产成人| 亚洲av琪琪男人的天堂| 人妻素人精油按摩中出| 97香蕉碰碰人妻国产樱花| 午夜精品亚洲精品五月色| 国产一区二区三免费视频| 国产亚洲视频在线二区| 天天日天天敢天天干| 亚洲男人在线天堂网| 93精品视频在线观看| 国产精品3p和黑人大战| 成人国产影院在线观看| 亚洲综合乱码一区二区| 人妻在线精品录音叫床| 啪啪啪啪啪啪啪免费视频| 午夜久久久久久久99| 直接观看免费黄网站| 黑人变态深video特大巨大| 综合激情网激情五月五月婷婷| 国产 在线 免费 精品| 久久精品亚洲国产av香蕉| 99久久99一区二区三区| 五十路丰满人妻熟妇| 人人妻人人人操人人人爽| 嫩草aⅴ一区二区三区| 韩国男女黄色在线观看| 天天操天天干天天插| 亚洲精品国产久久久久久| 人妻丝袜精品中文字幕| 国产精品sm调教视频| 久久久制服丝袜中文字幕| 国产之丝袜脚在线一区二区三区| 香蕉aⅴ一区二区三区| 日日夜夜精品一二三| 天天日天天干天天插舔舔| 五十路av熟女松本翔子| 日本熟妇色熟妇在线观看| 91人妻精品久久久久久久网站| 中文字幕午夜免费福利视频| 美女少妇亚洲精选av| 天天做天天干天天操天天射| 社区自拍揄拍尻屁你懂的| 日本xx片在线观看| 黄色片一级美女黄色片| 最新的中文字幕 亚洲| 亚洲国产欧美一区二区三区…| 97瑟瑟超碰在线香蕉| av俺也去在线播放| 国产视频在线视频播放| 精品av国产一区二区三区四区| 国产91精品拍在线观看| 高潮喷水在线视频观看| 人妻丰满熟妇综合网| 亚洲男人在线天堂网| 亚洲变态另类色图天堂网| 国产精品免费不卡av| 东游记中文字幕版哪里可以看到| 亚洲av香蕉一区区二区三区犇| 五月精品丁香久久久久福利社| 天美传媒mv视频在线观看| 深田咏美亚洲一区二区| 日本黄在免费看视频| 大胸性感美女羞爽操逼毛片| 天天日天天鲁天天操| 国产va精品免费观看| 日本精品一区二区三区在线视频。| 丝袜美腿欧美另类 中文字幕| 亚洲国产免费av一区二区三区| 91精品国产观看免费| 青青青青青免费视频| 黄网十四区丁香社区激情五月天| 无码精品一区二区三区人| 亚洲人妻视频在线网| 在线观看av亚洲情色| 天天操,天天干,天天射| 日韩精品激情在线观看| 青青在线视频性感少妇和隔壁黑丝 | 中字幕人妻熟女人妻a62v网| jiujiure精品视频在线| 啪啪啪啪啪啪啪啪av| 国产+亚洲+欧美+另类| 黄工厂精品视频在线观看| 馒头大胆亚洲一区二区| 18禁无翼鸟成人在线| 日本少妇在线视频大香蕉在线观看| 久久久极品久久蜜桃| 亚洲高清一区二区三区视频在线| 精品人妻一二三区久久| 国产亚洲欧美视频网站| 国产精品入口麻豆啊啊啊| 亚洲成高清a人片在线观看| 毛片av在线免费看| 免费一级黄色av网站| 福利视频广场一区二区| 亚洲在线观看中文字幕av| 午夜青青草原网在线观看| 亚洲欧美综合另类13p| 亚洲日产av一区二区在线| 亚国产成人精品久久久| 亚洲成人av一区久久| 夏目彩春在线中文字幕| 宅男噜噜噜666免费观看| 98视频精品在线观看| 操操网操操伊剧情片中文字幕网| 国产日本欧美亚洲精品视| 亚洲综合另类精品小说| 免费在线播放a级片| 人妻久久无码中文成人| 男人天堂av天天操| 精品91高清在线观看| 日本a级视频老女人| 天天日天天做天天日天天做| 中文字幕 人妻精品| 欧美视频中文一区二区三区| 中文字幕一区二 区二三区四区 | av老司机精品在线观看| 最新激情中文字幕视频| 精品国产成人亚洲午夜| 欧美国品一二三产区区别| 端庄人妻堕落挣扎沉沦| 在线新三级黄伊人网| 免费男阳茎伸入女阳道视频| 中文字幕第三十八页久久| 97瑟瑟超碰在线香蕉| 午夜精品一区二区三区更新| 久久免费看少妇高潮完整版| 99久久99一区二区三区| 一区二区三区国产精选在线播放| 国产亚洲精品品视频在线| 自拍偷区二区三区麻豆| 亚洲少妇人妻无码精品| 成人sm视频在线观看| 和邻居少妇愉情中文字幕| 激情色图一区二区三区| 最近中文2019年在线看| 午夜激情高清在线观看| 早川濑里奈av黑人番号| 亚洲成人av一区在线| 亚洲一区二区三区久久午夜| 在线新三级黄伊人网| 偷拍美女一区二区三区| 国产黄色高清资源在线免费观看| 亚洲成人熟妇一区二区三区| 自拍偷拍日韩欧美一区二区| 免费69视频在线看| 男生舔女生逼逼的视频| 绝顶痉挛大潮喷高潮无码 | 日本女人一级免费片| 亚洲综合一区成人在线| 丝袜长腿第一页在线| 蜜臀av久久久久久久| 99久久99久国产黄毛片| h国产小视频福利在线观看| 亚洲中文字字幕乱码| 欧美精品 日韩国产| 天天干天天操天天扣| 自拍偷拍日韩欧美一区二区| 国产女人被做到高潮免费视频| 精品高跟鞋丝袜一区二区| 色婷婷综合激情五月免费观看| 亚洲伊人色一综合网| 青青青青青青青在线播放视频 | 日韩av有码一区二区三区4| 毛片av在线免费看| 性色蜜臀av一区二区三区| 首之国产AV医生和护士小芳| 免费黄高清无码国产| 亚洲av成人网在线观看| 啪啪啪啪啪啪啪免费视频| 一区二区在线视频中文字幕| 欧美va不卡视频在线观看| 中文字幕av第1页中文字幕| 97小视频人妻一区二区| 久久久精品精品视频视频| 大鸡巴插入美女黑黑的阴毛| 午夜精品一区二区三区福利视频| 99热99这里精品6国产| 亚洲免费福利一区二区三区| 欧美日韩v中文在线| 亚洲熟妇x久久av久久| 男人插女人视频网站| 青青青青青免费视频| 老鸭窝在线观看一区| 亚洲一级av无码一级久久精品| 精品一区二区三四区| 摧残蹂躏av一二三区| 国产麻豆剧传媒精品国产av蜜桃| 91精品国产91青青碰| 一区二区三区激情在线| 青青尤物在线观看视频网站| 香蕉av影视在线观看| 1区2区3区4区视频在线观看| 亚洲 中文 自拍 另类 欧美| 成人在线欧美日韩国产| 国产精品黄色的av| 直接能看的国产av| 国产福利小视频大全| 99精品免费观看视频| 熟妇一区二区三区高清版| 日本少妇的秘密免费视频| 国产精品黄片免费在线观看| 亚洲第17页国产精品| 91色网站免费在线观看| 91精品资源免费观看| 东游记中文字幕版哪里可以看到| www,久久久,com| 蜜桃视频入口久久久| 夜夜嗨av蜜臀av| 中文字母永久播放1区2区3区| 91人妻精品久久久久久久网站| 欲乱人妻少妇在线视频裸| 大陆胖女人与丈夫操b国语高清| 天天操天天插天天色| 免费在线观看视频啪啪| 欧美精品中文字幕久久二区| 中文字幕在线免费第一页| 蜜桃视频入口久久久| 亚洲自拍偷拍精品网| 国内资源最丰富的网站| 国产视频网站一区二区三区| 中国熟女一区二区性xx| 岛国免费大片在线观看 | 日本女大学生的黄色小视频| 国产片免费观看在线观看| 欧洲国产成人精品91铁牛tv| 亚洲一区二区人妻av| 在线观看免费视频色97| 亚洲一区二区三区精品视频在线| 伊人网中文字幕在线视频| 粉嫩小穴流水视频在线观看| 中国黄色av一级片| 国产亚洲精品品视频在线| 中文字幕无码日韩专区免费| 欧美另类一区二区视频| 国产麻豆精品人妻av| 天天通天天透天天插| 人妻另类专区欧美制服| 激情色图一区二区三区| 在线免费观看99视频| 天天操天天射天天操天天天| av完全免费在线观看av| 国产成人午夜精品福利| 伊拉克及约旦宣布关闭领空| 精品人人人妻人人玩日产欧| 亚洲精品 日韩电影| 欧美日韩精品永久免费网址| 精品成人午夜免费看| 99热国产精品666| 免费看美女脱光衣服的视频| 欧美男人大鸡吧插女人视频| 国产精选一区在线播放| 免费av岛国天堂网站| 亚洲福利精品福利精品福利 | 一区二区三区美女毛片| 成人sm视频在线观看| 人妻少妇精品久久久久久 | 亚洲熟妇x久久av久久| 91国语爽死我了不卡| 75国产综合在线视频| 天天日天天日天天擦| 天天操夜夜骑日日摸| av黄色成人在线观看| 国产精品伦理片一区二区| 男人和女人激情视频| 香蕉aⅴ一区二区三区| 中字幕人妻熟女人妻a62v网| 国产精品午夜国产小视频| 亚洲中文字字幕乱码| 国产麻豆剧传媒精品国产av蜜桃| xxx日本hd高清| 国产在线观看免费人成短视频| 在线免费观看视频一二区| 三上悠亚和黑人665番号| 曰本无码人妻丰满熟妇啪啪| 人妻少妇一区二区三区蜜桃| 玖玖一区二区在线观看| 人妻熟女在线一区二区| 国产黑丝高跟鞋视频在线播放| 国产亚洲精品欧洲在线观看| 美味人妻2在线播放| 成人蜜臀午夜久久一区| 黄网十四区丁香社区激情五月天| 天天草天天色天天干| 老熟妇xxxhd老熟女| 青青青青操在线观看免费| 含骚鸡巴玩逼逼视频| 青草久久视频在线观看| 又色又爽又黄的美女裸体| 人妻久久无码中文成人| 福利一二三在线视频观看| 中文字母永久播放1区2区3区| 一区二区三区激情在线| 久久久久久99国产精品| 欧美在线偷拍视频免费看| 亚洲综合乱码一区二区| 国产午夜男女爽爽爽爽爽视频 | 蜜桃久久久久久久人妻| 亚洲图片欧美校园春色| 免费手机黄页网址大全| 国产熟妇人妻ⅹxxxx麻豆| 一二三区在线观看视频| 免费在线看的黄网站| 4个黑人操素人视频网站精品91| 国产极品精品免费视频| 欧美亚洲牲夜夜综合久久| 在线亚洲天堂色播av电影| 国产一区二区神马久久| 亚洲成人av在线一区二区| 40道精品招牌菜特色| 欧美成人黄片一区二区三区 | 国产黄色片在线收看| 亚洲欧美综合另类13p| 成人免费公开视频无毒| 韩国爱爱视频中文字幕| 老熟妇xxxhd老熟女| 天天日天天爽天天干| 欧美亚洲一二三区蜜臀| 99亚洲美女一区二区三区| 激情五月婷婷综合色啪| 青青青aaaa免费| 最新91九色国产在线观看| 亚洲国产精品黑丝美女| 岛国一区二区三区视频在线| 亚洲 自拍 色综合图| 国产亚洲视频在线观看| 成年女人免费播放视频| 亚洲中文精品人人免费| 国产激情av网站在线观看| 非洲黑人一级特黄片| 密臀av一区在线观看| 1区2区3区不卡视频| 日韩欧美在线观看不卡一区二区| 中文字幕欧美日韩射射一| 888欧美视频在线| 精品欧美一区二区vr在线观看| 2012中文字幕在线高清| 男女啪啪视频免费在线观看| 中文字幕在线欧美精品| 日韩无码国产精品强奸乱伦| 99精品国产aⅴ在线观看| 亚洲av人人澡人人爽人人爱| 国产黄色大片在线免费播放| 欧美一区二区三区高清不卡tv | 日本高清成人一区二区三区| 人人妻人人爱人人草| 日本最新一二三区不卡在线| 国产av自拍偷拍盛宴| 国产又粗又黄又硬又爽| 福利午夜视频在线观看| 美女 午夜 在线视频| 亚洲成高清a人片在线观看| 女人精品内射国产99| 欧美在线精品一区二区三区视频| 国产精品探花熟女在线观看| 综合国产成人在线观看| 日本免费午夜视频网站| 激情伦理欧美日韩中文字幕| 在线观看的a站 最新| 韩国AV无码不卡在线播放| 日韩二区视频一线天婷婷五| 亚洲熟女综合色一区二区三区四区| 国产成人精品福利短视频| 女生被男生插的视频网站| 亚洲成人午夜电影在线观看| 动漫美女的小穴视频| 91自产国产精品视频| 欧美日韩国产一区二区三区三州| 在线 中文字幕 一区| 午夜精品福利一区二区三区p| 888欧美视频在线| 欧美黑人巨大性xxxxx猛交| 亚洲av色香蕉一区二区三区 | 成年人午夜黄片视频资源| 日本一二三中文字幕| 日日摸夜夜添夜夜添毛片性色av| 扒开让我视频在线观看| 性色av一区二区三区久久久 | 福利视频广场一区二区| 桃色视频在线观看一区二区 | brazzers欧熟精品系列| 久久久噜噜噜久久熟女av| 色综合久久无码中文字幕波多| 中文字幕熟女人妻久久久| 亚洲av午夜免费观看| 自拍偷拍亚洲精品第2页| 91麻豆精品91久久久久同性| 最新91精品视频在线| 2022国产精品视频| 午夜福利资源综合激情午夜福利资| 激情五月婷婷免费视频| 亚洲av日韩精品久久久| 日本韩国免费一区二区三区视频 | 丝袜肉丝一区二区三区四区在线 | 久久热久久视频在线观看| 天天插天天狠天天操| 白嫩白嫩美女极品国产在线观看| 欧美国产亚洲中英文字幕| 大胸性感美女羞爽操逼毛片| 国产真实灌醉下药美女av福利| 日韩精品啪啪视频一道免费| 亚洲av琪琪男人的天堂| 老司机免费福利视频网| 亚洲av日韩精品久久久| 亚洲精品无码久久久久不卡| 日本中文字幕一二区视频| 国产又粗又黄又硬又爽| 日本www中文字幕| 粉嫩av懂色av蜜臀av| 天天日天天日天天射天天干| 青草青永久在线视频18| 55夜色66夜色国产精品站| 人妻少妇亚洲精品中文字幕| 国产视频精品资源网站| 韩国一级特黄大片做受| av在线播放国产不卡| 人妻另类专区欧美制服| av无限看熟女人妻另类av| 护士小嫩嫩又紧又爽20p| 在线观看视频网站麻豆| 国产一区二区神马久久| 91精品国产观看免费| 欧美一区二区三区高清不卡tv| 黄色录像鸡巴插进去| 五月婷婷在线观看视频免费| 40道精品招牌菜特色| 蜜桃视频入口久久久| 亚洲图库另类图片区| 国产卡一卡二卡三乱码手机| 亚洲成人三级在线播放| 亚洲激情偷拍一区二区| 中文字幕,亚洲人妻| 亚洲另类综合一区小说| 亚洲图片欧美校园春色| 国产片免费观看在线观看| 国产在线免费观看成人| 久久永久免费精品人妻专区| 男人的天堂av日韩亚洲| 成人av亚洲一区二区| 老司机免费福利视频网| 亚洲va天堂va国产va久| 婷婷色中文亚洲网68| 日本韩国亚洲综合日韩欧美国产| 国产又粗又猛又爽又黄的视频美国| 亚洲天堂av最新网址| 亚洲最大黄 嗯色 操 啊| 成人H精品动漫在线无码播放| 999九九久久久精品| 日本少妇的秘密免费视频| 亚洲av成人免费网站| 国产精品人妻一区二区三区网站 | 黄色片年轻人在线观看| 亚洲区美熟妇久久久久| 黄色成人在线中文字幕| 国产妇女自拍区在线观看| 喷水视频在线观看这里只有精品| 久久久极品久久蜜桃| 人妻爱爱 中文字幕| 青青草精品在线视频观看| 偷拍自拍福利视频在线观看| 精品美女久久久久久| 亚欧在线视频你懂的| 又粗又长 明星操逼小视频| 国产熟妇人妻ⅹxxxx麻豆| tube69日本少妇| av日韩在线观看大全| 国产熟妇一区二区三区av| 超级碰碰在线视频免费观看| av网址在线播放大全| 亚洲免费av在线视频| 亚洲熟妇无码一区二区三区| 日本脱亚入欧是指什么| 手机看片福利盒子日韩在线播放| 国产极品美女久久久久久| 欧美第一页在线免费观看视频| 中文字幕第三十八页久久| 精品少妇一二三视频在线| 超碰在线观看免费在线观看| 国产亚洲四十路五十路| 人妻无码中文字幕专区| 精品少妇一二三视频在线| 日韩二区视频一线天婷婷五| 亚洲视频乱码在线观看| 91九色porny蝌蚪国产成人| 五十路av熟女松本翔子| 国产精品黄片免费在线观看| 在线观看成人国产电影| av中文字幕在线观看第三页| 美女张开腿让男生操在线看| 88成人免费av网站| 日本熟妇丰满厨房55| 91免费黄片可看视频 | 日本在线不卡免费视频| 国产熟妇人妻ⅹxxxx麻豆| tube69日本少妇| 东京热男人的av天堂| 成年午夜免费无码区| 熟女妇女老妇一二三区| 人妻少妇精品久久久久久| 四虎永久在线精品免费区二区| 国产va精品免费观看| 午夜精品一区二区三区4| 又粗又长 明星操逼小视频| 国产91久久精品一区二区字幕| 中文字幕之无码色多多| 久久精品36亚洲精品束缚| 久久这里只有精彩视频免费| 精品av久久久久久久| 极品粉嫩小泬白浆20p主播| 自拍 日韩 欧美激情| 特级无码毛片免费视频播放| 欧美在线偷拍视频免费看| brazzers欧熟精品系列| 久草视频首页在线观看| 阴茎插到阴道里面的视频| 久久精品美女免费视频| 91精品国产综合久久久蜜| 黄片大全在线观看观看| 国产精品女邻居小骚货| 激情五月婷婷综合色啪| 丝袜肉丝一区二区三区四区在线| 十八禁在线观看地址免费| 九色porny九色9l自拍视频| 精品91自产拍在线观看一区| 久久久精品欧洲亚洲av| 亚洲综合一区成人在线| 黄工厂精品视频在线观看| 一区二区麻豆传媒黄片| 天天色天天操天天舔| 天天想要天天操天天干| h国产小视频福利在线观看| 91极品新人『兔兔』精品新作| 91亚洲手机在线视频播放| 夜夜骑夜夜操夜夜奸| av日韩在线免费播放| 国产乱弄免费视频观看| 91一区精品在线观看| 亚洲精品国品乱码久久久久| 亚洲国产在人线放午夜| caoporm超碰国产| 日本成人一区二区不卡免费在线| 成熟熟女国产精品一区| 99人妻视频免费在线| 日本一区精品视频在线观看| 青草亚洲视频在线观看| 一区二区三区四区视频在线播放| 中文字幕网站你懂的| 最新国产亚洲精品中文在线| 伊人网中文字幕在线视频| 成人国产影院在线观看| 少妇高潮无套内谢麻豆| 精品亚洲中文字幕av| 天天操天天干天天日狠狠插| 一区国内二区日韩三区欧美| 欧美精品激情在线最新观看视频| 日本美女性生活一级片| 中文字幕人妻av在线观看| 日本黄色特一级视频| 夫妻在线观看视频91| 亚洲精品一区二区三区老狼| 91久久国产成人免费网站| 天天操夜夜操天天操天天操| 国产黄色片蝌蚪九色91| 免费69视频在线看| 日本性感美女视频网站| 啪啪啪18禁一区二区三区| 一个色综合男人天堂| 中文字幕欧美日韩射射一| 视频一区 二区 三区 综合| 午夜精品福利91av| 中文字幕午夜免费福利视频| 红杏久久av人妻一区| 国产日韩av一区二区在线| 精品视频一区二区三区四区五区| 精品国产成人亚洲午夜| 色综合久久五月色婷婷综合| 中文字幕网站你懂的| 亚洲无线观看国产高清在线| 精品久久久久久久久久久久人妻| 欧美综合婷婷欧美综合| 揄拍成人国产精品免费看视频| 亚洲 中文字幕在线 日韩| 国产妇女自拍区在线观看| 黑人巨大精品欧美视频| 亚洲午夜福利中文乱码字幕| 93人妻人人揉人人澡人人| 欧美在线精品一区二区三区视频 | av乱码一区二区三区| 中文字日产幕乱六区蜜桃| 美女日逼视频免费观看| 日本三极片视频网站观看| 国产白嫩美女一区二区| 亚洲最大黄了色网站| 大鸡八强奸视频在线观看| 这里只有精品双飞在线播放| 日本性感美女三级视频| av久久精品北条麻妃av观看| 亚洲高清免费在线观看视频| 9色在线视频免费观看| 99久久激情婷婷综合五月天| 乱亲女秽乱长久久久| 又色又爽又黄又刺激av网站| 97a片免费在线观看| 熟妇一区二区三区高清版| 美女张开腿让男生操在线看| 中文字幕无码日韩专区免费| 国产大学生援交正在播放| 91小伙伴中女熟女高潮| 国产亚洲欧美另类在线观看| 亚洲国产成人av在线一区| 国产视频一区二区午夜| 国产精品大陆在线2019不卡 | 天堂女人av一区二区| 初美沙希中文字幕在线 | 色哟哟国产精品入口| 亚洲另类伦春色综合小| 91片黄在线观看喷潮| 天天日天天干天天爱| 97超碰免费在线视频| 一区二区三区激情在线| av天堂中文免费在线| 人妻少妇中文有码精品| 国语对白xxxx乱大交| 亚洲欧洲一区二区在线观看| 国产1区,2区,3区| 亚洲中文精品人人免费| 综合色区亚洲熟妇shxstz| 中文字幕+中文字幕| 欧美日韩情色在线观看| 国产欧美精品不卡在线| 亚洲精品麻豆免费在线观看 | 国产欧美日韩第三页| 欧美视频综合第一页| 成年人黄视频在线观看| 大香蕉日本伊人中文在线| 91麻豆精品91久久久久同性| 38av一区二区三区| 人妻另类专区欧美制服| 国产一区二区三免费视频| 超碰公开大香蕉97| 久草视频在线看免费| 国产综合精品久久久久蜜臀| 不卡一不卡二不卡三| 手机看片福利盒子日韩在线播放| 一级a看免费观看网站| 亚洲精品乱码久久久本| 午夜久久香蕉电影网| 欧美日韩高清午夜蜜桃大香蕉| 黄色片一级美女黄色片| 黄色视频成年人免费观看| 中文字日产幕乱六区蜜桃| 一区二区三区激情在线| 精内国产乱码久久久久久| 91九色porny蝌蚪国产成人| 亚洲一级av无码一级久久精品| 最新中文字幕乱码在线| 51国产成人精品视频| 操操网操操伊剧情片中文字幕网| 又色又爽又黄的美女裸体| 在线播放 日韩 av| 日韩亚国产欧美三级涩爱| 亚洲欧美激情中文字幕| 扒开腿挺进肉嫩小18禁视频| 视频一区二区三区高清在线| 99精品亚洲av无码国产另类| 天堂女人av一区二区| 国内自拍第一页在线观看| 国产视频一区二区午夜| 免费黄高清无码国产| 在线观看免费视频网| 成人H精品动漫在线无码播放| 国产九色91在线视频| 国产真实灌醉下药美女av福利| 国产自拍在线观看成人| 亚洲欧美成人综合视频| 日韩伦理短片在线观看| 黄色成年网站午夜在线观看| 天天色天天舔天天射天天爽| 视频 国产 精品 熟女 | 日韩伦理短片在线观看| 亚洲另类综合一区小说| 99久久久无码国产精品性出奶水| 少妇人妻真实精品视频| 亚洲最大黄了色网站| 一区二区三区日韩久久| 大鸡巴操娇小玲珑的女孩逼| 中文字幕成人日韩欧美| 高清一区二区欧美系列| 亚洲天堂精品福利成人av| 五十路熟女人妻一区二区9933| 久久99久久99精品影院| 亚洲第一黄色在线观看| 大鸡吧插逼逼视频免费看| 日韩少妇人妻精品无码专区| 自拍偷拍亚洲精品第2页| 久久99久久99精品影院| 亚洲最大黄了色网站| 亚洲av香蕉一区区二区三区犇| 久久美欧人妻少妇一区二区三区| 日本在线一区二区不卡视频| 亚洲av男人天堂久久| av欧美网站在线观看| 久久久久久久久久久久久97| 国产精品黄片免费在线观看| 色综合色综合色综合色| 宅男噜噜噜666国产| 免费手机黄页网址大全| 鸡巴操逼一级黄色气| 97成人免费在线观看网站| 欧美80老妇人性视频| 99re国产在线精品| 亚洲免费福利一区二区三区| 黄片三级三级三级在线观看| 蝴蝶伊人久久中文娱乐网| av中文字幕电影在线看| 亚洲 中文 自拍 无码| 9色在线视频免费观看| av在线观看网址av| 免费在线福利小视频| 都市激情校园春色狠狠| 一区二区三区四区视频在线播放| 亚洲综合一区成人在线| 青青青爽视频在线播放| 久草福利电影在线观看| 国产黄色片在线收看| 国产精品久久久久久久女人18| 亚洲中文字幕人妻一区| 成人资源在线观看免费官网| 伊人网中文字幕在线视频| 肏插流水妹子在线乐播下载| 久久精品亚洲国产av香蕉| 欧美精品国产综合久久| 黄色片一级美女黄色片| 一色桃子久久精品亚洲 | 新婚人妻聚会被中出| 亚洲va天堂va国产va久| 国产又粗又猛又爽又黄的视频美国| 亚洲国际青青操综合网站| 国产乱子伦一二三区| 国产免费高清视频视频| 少妇高潮一区二区三区| 扒开腿挺进肉嫩小18禁视频| 97精品视频在线观看| 一区二区三区在线视频福利| 亚洲精品高清自拍av| 欧美日韩人妻久久精品高清国产| 成人av电影免费版| 欧美一区二区中文字幕电影| 麻豆性色视频在线观看| 91大神福利视频网| 亚洲va国产va欧美精品88| 日曰摸日日碰夜夜爽歪歪| 一区二区三区四区五区性感视频| 国产自拍在线观看成人| 精品国产亚洲av一淫| 精品国产成人亚洲午夜| 黄色片一级美女黄色片| 日本欧美视频在线观看三区| 好吊操视频这里只有精品| 人妻久久无码中文成人| 懂色av之国产精品| 亚洲熟妇x久久av久久| 亚洲成人熟妇一区二区三区| 一区二区三区蜜臀在线| 亚洲高清自偷揄拍自拍| 鸡巴操逼一级黄色气| 沈阳熟妇28厘米大战黑人| 天天干天天操天天玩天天射| 狠狠鲁狠狠操天天晚上干干| 青青青激情在线观看视频| 中文字幕在线欧美精品| av乱码一区二区三区| 日本av在线一区二区三区| 91一区精品在线观看| 天堂av在线播放免费| 日本www中文字幕| 2020中文字幕在线播放| 久久久麻豆精亚洲av麻花| 在线观看国产网站资源| 国产欧美精品免费观看视频| 欧美日本国产自视大全| 55夜色66夜色国产精品站| 欧美性感尤物人妻在线免费看| 中文字幕乱码人妻电影| 丰满少妇人妻xxxxx| 在线制服丝袜中文字幕| 免费在线黄色观看网站| 成人免费做爰高潮视频| 精品视频一区二区三区四区五区| 亚洲精品欧美日韩在线播放| 色天天天天射天天舔| 色哟哟国产精品入口| 精品国产成人亚洲午夜| 亚洲 国产 成人 在线| h国产小视频福利在线观看| 中文字幕人妻被公上司喝醉在线| 婷婷激情四射在线观看视频| 亚洲成人av一区在线| 亚洲精品欧美日韩在线播放 | 欧美熟妇一区二区三区仙踪林| www天堂在线久久| 瑟瑟视频在线观看免费视频| 亚洲av日韩精品久久久久久hd| 欧美一区二区三区啪啪同性| 在线免费观看日本伦理| 国产成人精品av网站| 亚洲精品午夜久久久久| 熟女妇女老妇一二三区| 亚洲第17页国产精品| 色综合天天综合网国产成人| 老熟妇凹凸淫老妇女av在线观看 | 美女视频福利免费看| 天天干天天操天天插天天日| 男人天堂最新地址av| 97超碰免费在线视频| 亚洲午夜高清在线观看| 日本成人不卡一区二区| 水蜜桃一区二区三区在线观看视频| 在线新三级黄伊人网| 久久久精品精品视频视频| 偷拍美女一区二区三区| 欧美日韩亚洲国产无线码| 中文字幕无码一区二区免费| 国产精品精品精品999| 亚洲一区二区三区av网站| 欧美性感尤物人妻在线免费看| 日辽宁老肥女在线观看视频| 中文字幕最新久久久| 成人18禁网站在线播放| 视频一区二区三区高清在线| 亚洲青青操骚货在线视频| 成人H精品动漫在线无码播放| 日本一二三区不卡无| 极品粉嫩小泬白浆20p主播| 日韩美女搞黄视频免费| 韩国三级aaaaa高清视频| 91九色porny国产蝌蚪视频| 国产普通话插插视频| 天天干天天日天天干天天操| 亚洲精品在线资源站| 亚洲av成人免费网站| 国产av福利网址大全| 国产欧美精品免费观看视频| 伊人开心婷婷国产av| 国产极品精品免费视频| 日曰摸日日碰夜夜爽歪歪| 丝袜美腿欧美另类 中文字幕| 中文 成人 在线 视频| 中文字幕免费福利视频6| 九九视频在线精品播放| 在线播放 日韩 av| 亚洲av天堂在线播放| 国产女人被做到高潮免费视频| 日本三极片中文字幕| 熟女视频一区,二区,三区| 精品美女福利在线观看| 亚洲av第国产精品| 中文字幕网站你懂的| 亚洲精品午夜久久久久| 日韩av有码一区二区三区4| 一色桃子久久精品亚洲| 欧美一级视频一区二区| 亚洲国产成人最新资源| 亚洲 欧美 自拍 偷拍 在线| 亚洲熟妇久久无码精品| 99精品久久久久久久91蜜桃| 欧美日韩国产一区二区三区三州| 亚洲激情,偷拍视频| 天天干天天插天天谢| 国产精品日韩欧美一区二区| 日韩一区二区电国产精品| 日韩av大胆在线观看| 亚洲av日韩精品久久久久久hd| 97小视频人妻一区二区| 哥哥姐姐综合激情小说| 大屁股熟女一区二区三区| av天堂中文字幕最新| 超碰97人人澡人人| 少妇系列一区二区三区视频| 偷青青国产精品青青在线观看| 伊拉克及约旦宣布关闭领空| 懂色av之国产精品| 欧美一区二区三区四区性视频| 精品久久久久久高潮| 77久久久久国产精产品| 97香蕉碰碰人妻国产樱花| 91极品新人『兔兔』精品新作| 天天日天天干天天插舔舔| 亚洲自拍偷拍综合色| 三上悠亚和黑人665番号| 97人妻色免费视频| 日韩午夜福利精品试看| 日本裸体熟妇区二区欧美| 欧美一级视频一区二区| 精品av国产一区二区三区四区| 亚洲特黄aaaa片| gay gay男男瑟瑟在线网站| 午夜成午夜成年片在线观看| 少妇人妻二三区视频| 无码精品一区二区三区人| 精品久久久久久久久久久a√国产| 亚洲一区二区三区五区| 天天日天天玩天天摸| 亚洲变态另类色图天堂网| 免费看高清av的网站| 啪啪啪啪啪啪啪啪啪啪黄色| 久久久人妻一区二区| 亚洲在线免费h观看网站| 国产视频在线视频播放| 亚洲一区二区三区在线高清| 精品久久久久久久久久久久人妻| 日本在线不卡免费视频| 97精品成人一区二区三区| av高潮迭起在线观看| 久久久久久cao我的性感人妻| 任你操任你干精品在线视频| 人人妻人人人操人人人爽| 亚洲一区二区三区偷拍女厕91| 一本久久精品一区二区| 白嫩白嫩美女极品国产在线观看| 99热99re在线播放| 成人亚洲国产综合精品| 六月婷婷激情一区二区三区| 密臀av一区在线观看| av一区二区三区人妻| 大鸡八强奸视频在线观看| 国产成人精品一区在线观看| 亚洲av色图18p| 偷拍自拍亚洲视频在线观看| 五月天中文字幕内射| 精品一区二区亚洲欧美| 丰满少妇翘臀后进式| 国产日韩一区二区在线看 | 午夜婷婷在线观看视频| 日美女屁股黄邑视频| 又色又爽又黄的美女裸体| 小泽玛利亚视频在线观看| 国产一区av澳门在线观看| 久久精品久久精品亚洲人| 绯色av蜜臀vs少妇| 国产精品一区二区三区蜜臀av| 人人妻人人爽人人澡人人精品| 91香蕉成人app下载| 中英文字幕av一区| 亚洲av色香蕉一区二区三区| 成人网18免费视频版国产| 亚洲av成人网在线观看| 亚洲成人国产av在线| 久草视频福利在线首页| 欧美亚洲一二三区蜜臀| 成熟丰满熟妇高潮xx×xx | 性感美女福利视频网站| 91免费观看在线网站| 蜜臀av久久久久久久| 日本一本午夜在线播放| 亚洲成人三级在线播放| 亚洲精品三级av在线免费观看| 天天躁夜夜躁日日躁a麻豆| 美女张开两腿让男人桶av| 51国产偷自视频在线播放 | av在线资源中文字幕| 亚洲av无码成人精品区辽| 孕妇奶水仑乱A级毛片免费看| 国产成人精品亚洲男人的天堂| 超碰97人人做人人爱| 国产精品久久久黄网站| 人妻熟女在线一区二区| 亚洲 清纯 国产com| 中文字幕视频一区二区在线观看| 女警官打开双腿沦为性奴| 亚洲av自拍偷拍综合| 色97视频在线播放| 四川五十路熟女av| 天天干天天操天天摸天天射| 亚洲蜜臀av一区二区三区九色| 日本精品一区二区三区在线视频。| 青青青青草手机在线视频免费看| 天天躁日日躁狠狠躁躁欧美av| 美女 午夜 在线视频| 100%美女蜜桃视频| 男人的天堂一区二区在线观看| 亚洲av自拍天堂网| 亚洲国产成人av在线一区| 自拍偷拍vs一区二区三区| 唐人色亚洲av嫩草| 18禁美女羞羞免费网站| 欧美日韩不卡一区不区二区| 成人H精品动漫在线无码播放| 国产女孩喷水在线观看| 国产综合精品久久久久蜜臀| 成人性爱在线看四区| 精品老妇女久久9g国产| 岛国黄色大片在线观看| 91在线视频在线精品3| 夜鲁夜鲁狠鲁天天在线| 国产精品久久久久久久久福交| 只有精品亚洲视频在线观看| 岛国一区二区三区视频在线| 可以免费看的www视频你懂的| 东游记中文字幕版哪里可以看到| 一级黄片大鸡巴插入美女| 1024久久国产精品| 天天日天天玩天天摸| 99精品视频在线观看免费播放| 免费观看理论片完整版| 亚洲欧美色一区二区| 亚洲在线观看中文字幕av| 亚洲一区av中文字幕在线观看| 护士特殊服务久久久久久久| 午夜青青草原网在线观看| 岛国青草视频在线观看| 57pao国产一区二区| 亚洲av色图18p| 2025年人妻中文字幕乱码在线| 亚洲码av无色中文| 啪啪啪啪啪啪啪啪啪啪黄色| 大鸡巴后入爆操大屁股美女| 91免费福利网91麻豆国产精品| 中文字幕最新久久久| 大鸡八强奸视频在线观看| 亚洲2021av天堂| 蜜桃视频在线欧美一区| 人妻少妇性色欲欧美日韩| 韩国爱爱视频中文字幕| 大陆胖女人与丈夫操b国语高清 | 黑人巨大的吊bdsm| 日韩黄色片在线观看网站| 青青青青青青青青青青草青青| 日辽宁老肥女在线观看视频| 天天干天天日天天谢综合156| 视频在线亚洲一区二区| 亚洲日本一区二区久久久精品| 天堂va蜜桃一区入口| av在线免费观看亚洲天堂| 亚洲成人激情av在线| 久久机热/这里只有| 一级黄片久久久久久久久| 欧美区一区二区三视频| 午夜精品久久久久久99热| 93精品视频在线观看| 国产av欧美精品高潮网站| 扒开让我视频在线观看| 88成人免费av网站| 无码精品一区二区三区人| 成人H精品动漫在线无码播放| 美女被肏内射视频网站| 久久美欧人妻少妇一区二区三区| 97超碰国语国产97超碰| 自拍偷拍亚洲另类色图| 天天干夜夜操啊啊啊| 青青青国产片免费观看视频| av一区二区三区人妻| 美女福利视频网址导航| 日韩精品一区二区三区在线播放| 欧美一区二区三区高清不卡tv| 一区二区免费高清黄色视频| 大香蕉日本伊人中文在线| 91啪国自产中文字幕在线| 丝袜长腿第一页在线| av网址在线播放大全| 欧美一区二区三区激情啪啪啪| 制服丝袜在线人妻中文字幕| 欧美一区二区中文字幕电影| 国产综合高清在线观看| 最新国产亚洲精品中文在线| 大鸡八强奸视频在线观看| 人妻素人精油按摩中出| 欧美日韩激情啪啪啪| 美女视频福利免费看| 亚洲视频乱码在线观看| 国产九色91在线观看精品| 一区二区久久成人网| 亚洲国产免费av一区二区三区| 91 亚洲视频在线观看| 中文字幕,亚洲人妻| 日韩成人综艺在线播放| 人妻丝袜榨强中文字幕| 一本久久精品一区二区| 91精品国产91青青碰| 亚洲成人精品女人久久久| 青青社区2国产视频| 成人24小时免费视频| 9l人妻人人爽人人爽| 亚洲在线免费h观看网站| 美女在线观看日本亚洲一区| 青娱乐极品视频青青草| 91人妻人人做人人爽在线| 韩国亚洲欧美超一级在线播放视频| 九色视频在线观看免费| 国产精品一区二区久久久av| 精品av久久久久久久| 亚洲成人免费看电影| 综合激情网激情五月五月婷婷| tube69日本少妇| 在线免费视频 自拍| 日韩精品中文字幕福利| 国产麻豆91在线视频| 日视频免费在线观看| 亚洲人成精品久久久久久久| 国产麻豆国语对白露脸剧情| 成人性黑人一级av| 精品亚洲在线免费观看| 国产精品久久久黄网站| 欧美亚洲国产成人免费在线| 成人资源在线观看免费官网| 少妇与子乱在线观看| 国产精品精品精品999| 农村胖女人操逼视频| 国产精品久久综合久久| 亚洲黄色av网站免费播放| 岛国一区二区三区视频在线| 国产成人精品久久二区91| 亚洲福利天堂久久久久久 | 97人人模人人爽人人喊| av天堂加勒比在线| 日韩欧美亚洲熟女人妻| 亚洲欧美精品综合图片小说 | 午夜影院在线观看视频羞羞羞| 国产欧美日韩在线观看不卡| 亚洲成人黄色一区二区三区 | AV无码一区二区三区不卡| 久久久久只精品国产三级| 色狠狠av线不卡香蕉一区二区| 精品亚洲国产中文自在线| 久久三久久三久久三久久| 狠狠躁夜夜躁人人爽天天久天啪| 亚洲精品乱码久久久本| 欧美日韩在线精品一区二区三| 亚洲粉嫩av一区二区三区| 91国偷自产一区二区三区精品| 日韩美av高清在线| 日本一二三中文字幕| 清纯美女在线观看国产| 日日夜夜精品一二三| 99久久成人日韩欧美精品| 久草视频首页在线观看| 美日韩在线视频免费看| 中国把吊插入阴蒂的视频| 小泽玛利亚视频在线观看| 亚洲一区二区三区久久受| 久久久久久99国产精品| 日韩二区视频一线天婷婷五| 国产一区二区火爆视频| 日韩欧美中文国产在线| 日本一本午夜在线播放| 午夜在线精品偷拍一区二| 超碰97人人澡人人| 少妇与子乱在线观看| 国产黄色a级三级三级三级| 国产内射中出在线观看| 国产精品国产三级国产午| 亚洲天天干 夜夜操| 久久久久久久亚洲午夜综合福利| 中文字幕,亚洲人妻| 亚洲欧美激情人妻偷拍| 国产亚洲欧美视频网站| 国产精品日韩欧美一区二区| 美女操逼免费短视频下载链接 | 亚洲一级 片内射视正片| 男人的天堂在线黄色| 日本一二三中文字幕| 在线观看国产网站资源| 不卡一区一区三区在线| 91精品国产观看免费| 播放日本一区二区三区电影| 中文字幕高清资源站| 日本性感美女三级视频| 揄拍成人国产精品免费看视频| 亚洲综合在线观看免费| 999热精品视频在线| 亚洲天堂av最新网址| 五十路熟女人妻一区二| 丝袜肉丝一区二区三区四区在线| 亚欧在线视频你懂的| 黄工厂精品视频在线观看| 日韩av有码中文字幕| 巨乳人妻日下部加奈被邻居中出| 亚洲午夜电影之麻豆| 亚洲 国产 成人 在线| 视频一区 视频二区 视频| 亚洲人妻国产精品综合| 亚洲精品在线资源站| 日本少妇的秘密免费视频| 国产高清精品极品美女| 91九色porny蝌蚪国产成人| 自拍偷区二区三区麻豆| www天堂在线久久| 亚洲日产av一区二区在线| 色综合天天综合网国产成人| 黄色男人的天堂视频| 喷水视频在线观看这里只有精品| 中文字幕一区二区人妻电影冢本| 淫秽激情视频免费观看| 国产伦精品一区二区三区竹菊| 成人亚洲精品国产精品| 国产高清精品一区二区三区| 欧美久久一区二区伊人| 人妻无码中文字幕专区| 日本男女操逼视频免费看| 80电影天堂网官网| 精品一区二区三四区| 日韩欧美亚洲熟女人妻| 中文字幕高清资源站| 一级黄色av在线观看| 欧洲国产成人精品91铁牛tv| 91精品激情五月婷婷在线| 天天干天天日天天谢综合156| 另类av十亚洲av| 肏插流水妹子在线乐播下载| 91福利在线视频免费观看| 国产成人精品av网站| 美女少妇亚洲精选av| 大白屁股精品视频国产| 又粗又硬又猛又爽又黄的| 又大又湿又爽又紧A视频| 91高清成人在线视频| 日本性感美女写真视频| 免费在线观看视频啪啪| 人妻无码色噜噜狠狠狠狠色| 国产欧美日韩第三页| 青青青爽视频在线播放| 青青色国产视频在线| 亚洲av黄色在线网站| 久久久久五月天丁香社区| mm131美女午夜爽爽爽| 国产黄色片在线收看| 亚洲成人av一区在线| 在线观看av2025| 午夜免费体验区在线观看| 丝袜长腿第一页在线| 日韩精品中文字幕播放| 午夜91一区二区三区| 欧美女同性恋免费a| 97人妻夜夜爽二区欧美极品| 青青青国产免费视频| 中文字幕无码日韩专区免费| 馒头大胆亚洲一区二区| 亚洲特黄aaaa片| av天堂中文字幕最新| 9l人妻人人爽人人爽| 国产一区二区在线欧美| 亚洲精品麻豆免费在线观看| 高清成人av一区三区| 久久精品国产23696| 久久久精品欧洲亚洲av| 日韩欧美高清免费在线| 国产V亚洲V天堂无码欠欠| 伊人情人综合成人久久网小说| 久久精品国产999| 日本午夜爽爽爽爽爽视频在线观看 | 成人午夜电影在线观看 久久| 国产在线一区二区三区麻酥酥| 蜜桃视频入口久久久| 在线观看视频污一区| 可以在线观看的av中文字幕| 成人蜜桃美臀九一一区二区三区| 一区二区三区另类在线 | 黄色视频在线观看高清无码 | 免费人成黄页网站在线观看国产| 亚洲美女自偷自拍11页| 日韩一区二区三区三州| 日韩精品二区一区久久| 亚洲偷自拍高清视频| 视频一区二区在线免费播放| 9国产精品久久久久老师| 青青伊人一精品视频| gav成人免费播放| 成熟丰满熟妇高潮xx×xx| 欧美一区二区三区高清不卡tv| 日韩人妻丝袜中文字幕| 亚洲成人线上免费视频观看| 75国产综合在线视频| 亚欧在线视频你懂的| 91‖亚洲‖国产熟女| 精品区一区二区三区四区人妻| 日本丰满熟妇大屁股久久| 国产大学生援交正在播放| 五十路人妻熟女av一区二区| 91亚洲手机在线视频播放| 天天日天天爽天天干| 大陆av手机在线观看| 久精品人妻一区二区三区| 亚洲一区二区三区在线高清| 亚洲国产成人无码麻豆艾秋| free性日本少妇| 亚洲国产精品美女在线观看| 亚洲欧美激情国产综合久久久 | 在线观看视频 你懂的| 99av国产精品欲麻豆| av中文在线天堂精品| 99久久超碰人妻国产| 岳太深了紧紧的中文字幕| 人妻在线精品录音叫床| 欧美日韩不卡一区不区二区| 日本男女操逼视频免费看| 中文字幕视频一区二区在线观看| 国产精品国产精品一区二区| 天天干天天日天天谢综合156| 免费观看成年人视频在线观看| 老熟妇xxxhd老熟女| 日视频免费在线观看| 亚洲另类图片蜜臀av| 亚洲女人的天堂av| 一级黄色片夫妻性生活| 免费黄高清无码国产| 水蜜桃国产一区二区三区| 婷婷久久久综合中文字幕| xxx日本hd高清| 和邻居少妇愉情中文字幕| 精品国产亚洲av一淫| 亚洲av可乐操首页| 亚洲1区2区3区精华液| 91精品资源免费观看| 一区二区三区 自拍偷拍| 黄色成年网站午夜在线观看| 国产一区二区久久久裸臀| 亚洲精品 日韩电影| 成人av中文字幕一区| 色吉吉影音天天干天天操 | 天堂av在线官网中文| 五月精品丁香久久久久福利社| 夏目彩春在线中文字幕| 在线观看亚洲人成免费网址| 日本欧美视频在线观看三区| 馒头大胆亚洲一区二区| 青青伊人一精品视频| 岛国免费大片在线观看 | 中文字幕av一区在线观看| 99av国产精品欲麻豆| 亚洲 国产 成人 在线| 亚洲第一黄色在线观看| 欧美天堂av无线av欧美| 国产精品福利小视频a| 日韩av中文在线免费观看| 中文亚洲欧美日韩无线码| 久草视频在线一区二区三区资源站 | 亚洲少妇高潮免费观看| 久久久麻豆精亚洲av麻花| 一色桃子久久精品亚洲| 超污视频在线观看污污污| 中文字幕乱码av资源| 97国产精品97久久| 亚洲精品国偷自产在线观看蜜桃| 黄色录像鸡巴插进去| 91精品资源免费观看| 黄色的网站在线免费看| 中文字幕网站你懂的| av网站色偷偷婷婷网男人的天堂| 亚洲欧美另类手机在线| 精品久久久久久久久久久a√国产| 亚洲 自拍 色综合图| 成人资源在线观看免费官网| 黄色片年轻人在线观看| 成人av久久精品一区二区| yellow在线播放av啊啊啊| 成年人黄视频在线观看| 久久精品美女免费视频| 国产成人综合一区2区| 亚洲精品久久视频婷婷| 国产一级麻豆精品免费| aⅴ精产国品一二三产品| 一级黄片久久久久久久久| brazzers欧熟精品系列| 亚洲一级 片内射视正片| 精品一区二区三区三区色爱| 国产成人综合一区2区| huangse网站在线观看| 黄页网视频在线免费观看| 一级黄色片夫妻性生活| 91天堂精品一区二区| 国产高清女主播在线| 粉嫩欧美美人妻小视频| 中文字幕人妻av在线观看| 精品人妻伦一二三区久| 国产亚洲视频在线二区| 99亚洲美女一区二区三区| 中文字幕人妻被公上司喝醉在线| 亚洲一级av无码一级久久精品| 91在线视频在线精品3| 中文字幕一区二 区二三区四区| 国产janese在线播放| www,久久久,com| 91免费观看在线网站| 国产在线自在拍91国语自产精品 | 在线观看国产免费麻豆| 亚洲另类伦春色综合小| 2022国产精品视频| 2020国产在线不卡视频 | 日韩欧美高清免费在线| 91超碰青青中文字幕| 都市激情校园春色狠狠| 91桃色成人网络在线观看| 日本韩国免费一区二区三区视频| 黄工厂精品视频在线观看| 18禁美女黄网站色大片下载| 天天射夜夜操综合网| 国产亚洲精品视频合集| 岛国av高清在线成人在线| 日韩av熟妇在线观看| 青青青青操在线观看免费| 日本熟妇一区二区x x| 一区二区三区av高清免费| 亚洲1卡2卡三卡4卡在线观看| 日本脱亚入欧是指什么| 99热久久这里只有精品| 99久久99一区二区三区| 一区二区三区综合视频| 精品一区二区三区午夜| 青青青青青青青在线播放视频| 亚洲一区二区久久久人妻| 瑟瑟视频在线观看免费视频| 懂色av之国产精品| 精品国产午夜视频一区二区| 色综合天天综合网国产成人| 亚洲午夜电影在线观看| 桃色视频在线观看一区二区| 欧美一级视频一区二区| 亚洲一区久久免费视频| 国产精品一区二区三区蜜臀av| 国产成人自拍视频在线免费观看| 国产精品自拍在线视频| 亚洲嫩模一区二区三区| 一区二区三区综合视频| 亚洲最大免费在线观看| 玩弄人妻熟妇性色av少妇| 熟女少妇激情五十路| av大全在线播放免费| 91小伙伴中女熟女高潮| 中出中文字幕在线观看| 国产女孩喷水在线观看| 精品国产在线手机在线| 亚洲1069综合男同| 中文字幕第1页av一天堂网| 家庭女教师中文字幕在线播放| 黑人解禁人妻叶爱071| 欧美va不卡视频在线观看| 欧美 亚洲 另类综合| 中文字幕人妻一区二区视频| 十八禁在线观看地址免费| 蜜桃视频入口久久久| www,久久久,com| 最新中文字幕免费视频| 91国内精品久久久久精品一| 538精品在线观看视频| www日韩毛片av| 亚洲av色图18p| 绝顶痉挛大潮喷高潮无码 | 国产综合高清在线观看| 日本精品一区二区三区在线视频。| 天天操天天污天天射| 亚洲中文字幕国产日韩| 18禁精品网站久久| 日本后入视频在线观看 | 亚洲伊人av天堂有码在线| 国产第一美女一区二区三区四区 | 超碰公开大香蕉97| 久草视频中文字幕在线观看| 自拍偷区二区三区麻豆| 色综合久久无码中文字幕波多| 同居了嫂子在线播高清中文| 日韩少妇人妻精品无码专区| 男人在床上插女人视频| 综合精品久久久久97| 亚洲天堂成人在线观看视频网站| 中文字幕高清免费在线人妻| 91免费福利网91麻豆国产精品| 天天综合天天综合天天网 | 高清成人av一区三区| 最近中文字幕国产在线| 极品性荡少妇一区二区色欲| 国产精品国产三级国产午| 日本性感美女视频网站| 天天躁日日躁狠狠躁躁欧美av| 亚洲国产在线精品国偷产拍| 久久久制服丝袜中文字幕| 天天插天天色天天日| 成人色综合中文字幕| 一二三中文乱码亚洲乱码one| 在线国产日韩欧美视频| 中文字幕一区二区人妻电影冢本 | 美女福利写真在线观看视频| 欧美日韩亚洲国产无线码| 国产精品免费不卡av|