婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > SQL 存儲過程基礎語法之一

SQL 存儲過程基礎語法之一

熱門標簽:小e電話機器人 臨沂智能電銷機器人加盟哪家好 鎮江網路外呼系統供應商 貴州房產智能外呼系統供應商 一個導航軟件能用幾個地圖標注點 外呼運營商線路收費 申請400電話在哪辦理流程 百度地圖標注改顏色 電銷外呼有錄音系統有哪些
CREATE PROCEDURE
創建存儲過程,存儲過程是保存起來的可以接受和返回用戶提供的參數的 Transact-SQL 語句的集合。
可以創建一個過程供永久使用,或在一個會話中臨時使用(局部臨時過程),或在所有會話中臨時使用(全局臨時過程)。也可以創建在 Microsoft? SQL Server? 啟動時自動運行的存儲過程。

語法
CREATE PROC [ EDURE ] procedure_name [ ; number ]
[ { @parameter data_type }
[ VARYING ] [ = default ] [ OUTPUT ]
] [ ,...n ]
[ WITH
{ RECOMPILE | ENCRYPTION | RECOMPILE , ENCRYPTION } ]
[ FOR REPLICATION ]
AS sql_statement [ ...n ]
參數
procedure_name
新存儲過程的名稱。過程名必須符合標識符規則,且對于數據庫及其所有者必須唯一。有關更多信息,請參見使用標識符。
要創建局部臨時過程,可以在 procedure_name 前面加一個編號符 (#procedure_name),要創建全局臨時過程,可以在 procedure_name 前面加兩個編號符 (##procedure_name)。完整的名稱(包括 # 或 ##)不能超過 128 個字符。指定過程所有者的名稱是可選的。
;number
是可選的整數,用來對同名的過程分組,以便用一條 DROP PROCEDURE 語句即可將同組的過程一起除去。例如,名為 orders 的應用程序使用的過程可以命名為 orderproc;1、orderproc;2 等。DROP PROCEDURE orderproc 語句將除去整個組。如果名稱中包含定界標識符,則數字不應包含在標識符中,只應在 procedure_name 前后使用適當的定界符。
@parameter
過程中的參數。在 CREATE PROCEDURE 語句中可以聲明一個或多個參數。用戶必須在執行過程時提供每個所聲明參數的值(除非定義了該參數的默認值)。存儲過程最多可以有 2.100 個參數。
使用 @ 符號作為第一個字符來指定參數名稱。參數名稱必須符合標識符的規則。每個過程的參數僅用于該過程本身;相同的參數名稱可以用在其它過程中。默認情況下,參數只能代替常量,而不能用于代替表名、列名或其它數據庫對象的名稱。有關更多信息,請參見 EXECUTE。
data_type
參數的數據類型。所有數據類型(包括 text、ntext 和 image)均可以用作存儲過程的參數。不過,cursor 數據類型只能用于 OUTPUT 參數。如果指定的數據類型為 cursor,也必須同時指定 VARYING 和 OUTPUT 關鍵字。有關 SQL Server 提供的數據類型及其語法的更多信息,請參見數據類型。
說明 對于可以是 cursor 數據類型的輸出參數,沒有最大數目的限制。
VARYING
指定作為輸出參數支持的結果集(由存儲過程動態構造,內容可以變化)。僅適用于游標參數。
default
參數的默認值。如果定義了默認值,不必指定該參數的值即可執行過程。默認值必須是常量或 NULL。如果過程將對該參數使用 LIKE 關鍵字,那么默認值中可以包含通配符(%、_、[] 和 [^])。
OUTPUT
表明參數是返回參數。該選項的值可以返回給 EXEC[UTE]。使用 OUTPUT 參數可將信息返回給調用過程。Text、ntext 和 image 參數可用作 OUTPUT 參數。使用 OUTPUT 關鍵字的輸出參數可以是游標占位符。

表示最多可以指定 2.100 個參數的占位符。
{RECOMPILE | ENCRYPTION | RECOMPILE, ENCRYPTION}
RECOMPILE 表明 SQL Server 不會緩存該過程的計劃,該過程將在運行時重新編譯。在使用非典型值或臨時值而不希望覆蓋緩存在內存中的執行計劃時,請使用 RECOMPILE 選項。
ENCRYPTION 表示 SQL Server 加密 syscomments 表中包含 CREATE PROCEDURE 語句文本的條目。使用 ENCRYPTION 可防止將過程作為 SQL Server 復制的一部分發布。
說明 在升級過程中,SQL Server 利用存儲在 syscomments 中的加密注釋來重新創建加密過程。
FOR REPLICATION
指定不能在訂閱服務器上執行為復制創建的存儲過程。.使用 FOR REPLICATION 選項創建的存儲過程可用作存儲過程篩選,且只能在復制過程中執行。本選項不能和 WITH RECOMPILE 選項一起使用。
AS
指定過程要執行的操作。
sql_statement
過程中要包含的任意數目和類型的 Transact-SQL 語句。但有一些限制。

是表示此過程可以包含多條 Transact-SQL 語句的占位符。

注釋
存儲過程的最大大小為 128 MB。
用戶定義的存儲過程只能在當前數據庫中創建(臨時過程除外,臨時過程總是在 tempdb 中創建)。在單個批處理中,CREATE PROCEDURE 語句不能與其它 Transact-SQL 語句組合使用。
默認情況下,參數可為空。如果傳遞 NULL 參數值并且該參數在 CREATE 或 ALTER TABLE 語句中使用,而該語句中引用的列又不允許使用 NULL,則 SQL Server 會產生一條錯誤信息。為了防止向不允許使用 NULL 的列傳遞 NULL 參數值,應向過程中添加編程邏輯或為該列使用默認值(使用 CREATE 或 ALTER TABLE 的 DEFAULT 關鍵字)。
建議在存儲過程的任何 CREATE TABLE 或 ALTER TABLE 語句中都為每列顯式指定 NULL 或 NOT NULL,例如在創建臨時表時。ANSI_DFLT_ON 和 ANSI_DFLT_OFF 選項控制 SQL Server 為列指派 NULL 或 NOT NULL 特性的方式(如果在 CREATE TABLE 或 ALTER TABLE 語句中沒有指定的話)。如果某個連接執行的存儲過程對這些選項的設置與創建該過程的連接的設置不同,則為第二個連接創建的表列可能會有不同的為空性,并且表現出不同的行為方式。如果為每個列顯式聲明了 NULL 或 NOT NULL,那么將對所有執行該存儲過程的連接使用相同的為空性創建臨時表。
在創建或更改存儲過程時,SQL Server 將保存 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 的設置。執行存儲過程時,將使用這些原始設置。因此,所有客戶端會話的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 設置在執行存儲過程時都將被忽略。在存儲過程中出現的 SET QUOTED_IDENTIFIER 和 SET ANSI_NULLS 語句不影響存儲過程的功能。
其它 SET 選項(例如 SET ARITHABORT、SET ANSI_WARNINGS 或 SET ANSI_PADDINGS)在創建或更改存儲過程時不保存。如果存儲過程的邏輯取決于特定的設置,應在過程開頭添加一條 SET 語句,以確保設置正確。從存儲過程中執行 SET 語句時,該設置只在存儲過程完成之前有效。之后,設置將恢復為調用存儲過程時的值。這使個別的客戶端可以設置所需的選項,而不會影響存儲過程的邏輯。
說明 SQL Server 是將空字符串解釋為單個空格還是解釋為真正的空字符串,由兼容級別設置控制。如果兼容級別小于或等于 65,SQL Server 就將空字符串解釋為單個空格。如果兼容級別等于 70,則 SQL Server 將空字符串解釋為空字符串。有關更多信息,請參見 sp_dbcmptlevel。
獲得有關存儲過程的信息
若要顯示用來創建過程的文本,請在過程所在的數據庫中執行 sp_helptext,并使用過程名作為參數。
說明 使用 ENCRYPTION 選項創建的存儲過程不能使用 sp_helptext 查看。
若要顯示有關過程引用的對象的報表,請使用 sp_depends。
若要為過程重命名,請使用 sp_rename。

引用對象
SQL Server 允許創建的存儲過程引用尚不存在的對象。在創建時,只進行語法檢查。執行時,如果高速緩存中尚無有效的計劃,則編譯存儲過程以生成執行計劃。只有在編譯過程中才解析存儲過程中引用的所有對象。因此,如果語法正確的存儲過程引用了不存在的對象,則仍可以成功創建,但在運行時將失敗,因為所引用的對象不存在。有關更多信息,請參見延遲名稱解析和編譯。

延遲名稱解析和兼容級別
SQL Server 允許 Transact-SQL 存儲過程在創建時引用不存在的表。這種能力稱為延遲名稱解析。不過,如果 Transact-SQL 存儲過程引用了該存儲過程中定義的表,而兼容級別設置(通過執行 sp_dbcmptlevel 來設置)為 65,則在創建時會發出警告信息。而如果在運行時所引用的表不存在,將返回錯誤信息。有關更多信息,請參見 sp_dbcmptlevel 和延遲名稱解析和編譯。

執行存儲過程
成功執行 CREATE PROCEDURE 語句后,過程名稱將存儲在 sysobjects 系統表中,而 CREATE PROCEDURE 語句的文本將存儲在 syscomments 中。第一次執行時,將編譯該過程以確定檢索數據的最佳訪問計劃。

使用 cursor 數據類型的參數
存儲過程只能將 cursor 數據類型用于 OUTPUT 參數。如果為某個參數指定了 cursor 數據類型,也必須指定 VARYING 和 OUTPUT 參數。如果為某個參數指定了 VARYING 關鍵字,則數據類型必須是 cursor,并且必須指定 OUTPUT 關鍵字。
說明 cursor 數據類型不能通過數據庫 API(例如 OLE DB、ODBC、ADO 和 DB-Library)綁定到應用程序變量上。因為必須先綁定 OUTPUT 參數,應用程序才可以執行存儲過程,所以帶有 cursor OUTPUT 參數的存儲過程不能通過數據庫 API 調用。只有將 cursor OUTPUT 變量賦值給 Transact-SQL 局部 cursor 變量時,才可以通過 Transact-SQL 批處理、存儲過程或觸發器調用這些過程。

Cursor 輸出參數
在執行過程時,以下規則適用于 cursor 輸出參數:
對于只進游標,游標的結果集中返回的行只是那些存儲過程執行結束時處于或超出游標位置的行,例如:
在過程中的名為 RS 的 100 行結果集上打開一個非滾動游標。
過程提取結果集 RS 的頭 5 行。
過程返回到其調用者。
返回到調用者的結果集 RS 由 RS 的第 6 到 100 行組成,調用者中的游標處于 RS 的第一行之前。
對于只進游標,如果存儲過程完成后,游標位于第一行的前面,則整個結果集將返回給調用批處理、存儲過程或觸發器。返回時,游標將位于第一行的前面。
對于只進游標,如果存儲過程完成后,游標的位置超出最后一行的結尾,則為調用批處理、存儲過程或觸發器返回空結果集。
說明 空結果集與空值不同。
對于可滾動游標,在存儲過程執行結束時,結果集中的所有行均會返回給調用批處理、存儲過程或觸發器。返回時,游標保留在過程中最后一次執行提取時的位置。
對于任意類型的游標,如果游標關閉,則將空值傳遞回調用批處理、存儲過程或觸發器。如果將游標指派給一個參數,但該游標從未打開過,也會出現這種情況。
說明 關閉狀態只有在返回時才有影響。例如,可以在過程中關閉游標,稍后再打開游標,然后將該游標的結果集返回給調用批處理、存儲過程或觸發器。

臨時存儲過程
SQL Server 支持兩種臨時過程:局部臨時過程和全局臨時過程。局部臨時過程只能由創建該過程的連接使用。全局臨時過程則可由所有連接使用。局部臨時過程在當前會話結束時自動除去。全局臨時過程在使用該過程的最后一個會話結束時除去。通常是在創建該過程的會話結束時。
臨時過程用 # 和 ## 命名,可以由任何用戶創建。創建過程后,局部過程的所有者是唯一可以使用該過程的用戶。執行局部臨時過程的權限不能授予其他用戶。如果創建了全局臨時過程,則所有用戶均可以訪問該過程,權限不能顯式廢除。只有在 tempdb 數據庫中具有顯式 CREATE PROCEDURE 權限的用戶,才可以在該數據庫中顯式創建臨時過程(不使用編號符命名)。可以授予或廢除這些過程中的權限。
說明 頻繁使用臨時存儲過程會在 tempdb 中的系統表上產生爭用,從而對性能產生負面影響。建議使用 sp_executesql 代替。sp_executesql 不在系統表中存儲數據,因此可以避免這一問題。

自動執行存儲過程
SQL Server 啟動時可以自動執行一個或多個存儲過程。這些存儲過程必須由系統管理員創建,并在 sysadmin 固定服務器角色下作為后臺過程執行。這些過程不能有任何輸入參數。
對啟動過程的數目沒有限制,但是要注意,每個啟動過程在執行時都會占用一個連接。如果必須在啟動時執行多個過程,但不需要并行執行,則可以指定一個過程作為啟動過程,讓該過程調用其它過程。這樣就只占用一個連接。
在啟動時恢復了最后一個數據庫后,即開始執行存儲過程。若要跳過這些存儲過程的執行,請將啟動參數指定為跟蹤標記 4022。如果以最低配置啟動 SQL Server(使用 -f 標記),則啟動存儲過程也不會執行。有關更多信息,請參見跟蹤標記。
若要創建啟動存儲過程,必須作為 sysadmin 固定服務器角色的成員登錄,并在 master 數據庫中創建存儲過程。
使用 sp_procoption 可以:
將現有存儲過程指定為啟動過程。
停止在 SQL Server 啟動時執行過程。
查看 SQL Server 啟動時執行的所有過程的列表。
存儲過程嵌套
存儲過程可以嵌套,即一個存儲過程可以調用另一個存儲過程。在被調用過程開始執行時,嵌套級將增加,在被調用過程執行結束后,嵌套級將減少。如果超出最大的嵌套級,會使整個調用過程鏈失敗。可用 @@NESTLEVEL 函數返回當前的嵌套級。
若要估計編譯后的存儲過程大小,請使用下列性能監視計數器。
性能監視器對象名 性能監視計數器名稱
SQLServer:緩沖區管理器 高速緩存大小(頁面數)
SQLServer:高速緩存管理器 高速緩存命中率
高速緩存頁
高速緩存對象計數*
* 各種分類的高速緩存對象均可以使用這些計數器,包括特殊 sql、準備 sql、過程、觸發器等。
有關更多信息,請參見 SQL Server:Buffer Manager 對象和 SQL Server:Cache Manager 對象。

sql_statement 限制
除了 SET SHOWPLAN_TEXT 和 SET SHOWPLAN_ALL 之外(這兩個語句必須是批處理中僅有的語句),任何 SET 語句均可以在存儲過程內部指定。所選擇的 SET 選項在存儲過程執行過程中有效,之后恢復為原來的設置。
如果其他用戶要使用某個存儲過程,那么在該存儲過程內部,一些語句使用的對象名必須使用對象所有者的名稱限定。這些語句包括:
ALTER TABLE
CREATE INDEX
CREATE TABLE
所有 DBCC 語句
DROP TABLE
DROP INDEX
TRUNCATE TABLE
UPDATE STATISTICS

權限
CREATE PROCEDURE 的權限默認授予 sysadmin 固定服務器角色成員和 db_owner 和 db_ddladmin 固定數據庫角色成員。sysadmin 固定服務器角色成員和 db_owner 固定數據庫角色成員可以將 CREATE PROCEDURE 權限轉讓給其他用戶。執行存儲過程的權限授予過程的所有者,該所有者可以為其它數據庫用戶設置執行權限。

示例
A. 使用帶有復雜 SELECT 語句的簡單過程
下面的存儲過程從四個表的聯接中返回所有作者(提供了姓名)、出版的書籍以及出版社。該存儲過程不使用任何參數。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info_all' AND type = 'P')
DROP PROCEDURE au_info_all
GO
CREATE PROCEDURE au_info_all
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
GO
au_info_all 存儲過程可以通過以下方法執行:
EXECUTE au_info_all
-- Or
EXEC au_info_all
如果該過程是批處理中的第一條語句,則可使用:
au_info_all
B. 使用帶有參數的簡單過程
下面的存儲過程從四個表的聯接中只返回指定的作者(提供了姓名)、出版的書籍以及出版社。該存儲過程接受與傳遞的參數精確匹配的值。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info' AND type = 'P')
DROP PROCEDURE au_info
GO
USE pubs
GO
CREATE PROCEDURE au_info
@lastname varchar(40),
@firstname varchar(20)
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
WHERE au_fname = @firstname
AND au_lname = @lastname
GO
au_info 存儲過程可以通過以下方法執行:
EXECUTE au_info 'Dull', 'Ann'
-- Or
EXECUTE au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXECUTE au_info @firstname = 'Ann', @lastname = 'Dull'
-- Or
EXEC au_info 'Dull', 'Ann'
-- Or
EXEC au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
EXEC au_info @firstname = 'Ann', @lastname = 'Dull'
如果該過程是批處理中的第一條語句,則可使用:
au_info 'Dull', 'Ann'
-- Or
au_info @lastname = 'Dull', @firstname = 'Ann'
-- Or
au_info @firstname = 'Ann', @lastname = 'Dull'
C. 使用帶有通配符參數的簡單過程
下面的存儲過程從四個表的聯接中只返回指定的作者(提供了姓名)、出版的書籍以及出版社。該存儲過程對傳遞的參數進行模式匹配,如果沒有提供參數,則使用預設的默認值。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'au_info2' AND type = 'P')
DROP PROCEDURE au_info2
GO
USE pubs
GO
CREATE PROCEDURE au_info2
@lastname varchar(30) = 'D%',
@firstname varchar(18) = '%'
AS
SELECT au_lname, au_fname, title, pub_name
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON t.title_id = ta.title_id INNER JOIN publishers p
ON t.pub_id = p.pub_id
WHERE au_fname LIKE @firstname
AND au_lname LIKE @lastname
GO
au_info2 存儲過程可以用多種組合執行。下面只列出了部分組合:
EXECUTE au_info2
-- Or
EXECUTE au_info2 'Wh%'
-- Or
EXECUTE au_info2 @firstname = 'A%'
-- Or
EXECUTE au_info2 '[CK]ars[OE]n'
-- Or
EXECUTE au_info2 'Hunter', 'Sheryl'
-- Or
EXECUTE au_info2 'H%', 'S%'
D. 使用 OUTPUT 參數
OUTPUT 參數允許外部過程、批處理或多條 Transact-SQL 語句訪問在過程執行期間設置的某個值。下面的示例創建一個存儲過程 (titles_sum),并使用一個可選的輸入參數和一個輸出參數。
首先,創建過程:
USE pubs
GO
IF EXISTS(SELECT name FROM sysobjects
WHERE name = 'titles_sum' AND type = 'P')
DROP PROCEDURE titles_sum
GO
USE pubs
GO
CREATE PROCEDURE titles_sum @@TITLE varchar(40) = '%', @@SUM money OUTPUT
AS
SELECT 'Title Name' = title
FROM titles
WHERE title LIKE @@TITLE
SELECT @@SUM = SUM(price)
FROM titles
WHERE title LIKE @@TITLE
GO
接下來,將該 OUTPUT 參數用于控制流語言
說明 OUTPUT 變量必須在創建表和使用該變量時都進行定義。
參數名和變量名不一定要匹配,不過數據類型和參數位置必須匹配(除非使用 @@SUM = variable 形式)。
DECLARE @@TOTALCOST money
EXECUTE titles_sum 'The%', @@TOTALCOST OUTPUT
IF @@TOTALCOST 200
BEGIN
PRINT ' '
PRINT 'All of these titles can be purchased for less than $200.'
END
ELSE
SELECT 'The total cost of these titles is $' + RTRIM(CAST(@@TOTALCOST AS varchar(20)))
下面是結果集:
Title Name
------------------------------------------------------------------------
The Busy Executive's Database Guide
The Gourmet Microwave
The Psychology of Computer Cooking
(3 row(s) affected)
Warning, null value eliminated from aggregate.
All of these titles can be purchased for less than $200.
E. 使用 OUTPUT 游標參數
OUTPUT 游標參數用來將存儲過程的局部游標傳遞回調用批處理、存儲過程或觸發器。
首先,創建以下過程,在 titles 表上聲明并打開一個游標:
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'titles_cursor' and type = 'P')
DROP PROCEDURE titles_cursor
GO
CREATE PROCEDURE titles_cursor @titles_cursor CURSOR VARYING OUTPUT
AS
SET @titles_cursor = CURSOR
FORWARD_ONLY STATIC FOR
SELECT * FROM titles
OPEN @titles_cursor
GO
接下來,執行一個批處理,聲明一個局部游標變量,執行上述過程以將游標賦值給局部變量,然后從該游標提取行。
USE pubs
GO
DECLARE @MyCursor CURSOR
EXEC titles_cursor @titles_cursor = @MyCursor OUTPUT
WHILE (@@FETCH_STATUS = 0)
BEGIN
FETCH NEXT FROM @MyCursor
END
CLOSE @MyCursor
DEALLOCATE @MyCursor
GO
F. 使用 WITH RECOMPILE 選項
如果為過程提供的參數不是典型的參數,并且新的執行計劃不應高速緩存或存儲在內存中,WITH RECOMPILE 子句會很有幫助。
USE pubs
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'titles_by_author' AND type = 'P')
DROP PROCEDURE titles_by_author
GO
CREATE PROCEDURE titles_by_author @@LNAME_PATTERN varchar(30) = '%'
WITH RECOMPILE
AS
SELECT RTRIM(au_fname) + ' ' + RTRIM(au_lname) AS 'Authors full name',
title AS Title
FROM authors a INNER JOIN titleauthor ta
ON a.au_id = ta.au_id INNER JOIN titles t
ON ta.title_id = t.title_id
WHERE au_lname LIKE @@LNAME_PATTERN
GO
G. 使用 WITH ENCRYPTION 選項
WITH ENCRYPTION 子句對用戶隱藏存儲過程的文本。下例創建加密過程,使用 sp_helptext 系統存儲過程獲取關于加密過程的信息,然后嘗試直接從 syscomments 表中獲取關于該過程的信息。
IF EXISTS (SELECT name FROM sysobjects
WHERE name = 'encrypt_this' AND type = 'P')
DROP PROCEDURE encrypt_this
GO
USE pubs
GO
CREATE PROCEDURE encrypt_this
WITH ENCRYPTION
AS
SELECT * FROM authors
GO
EXEC sp_helptext encrypt_this
下面是結果集:
The object's comments have been encrypted.
接下來,選擇加密存儲過程內容的標識號和文本。
SELECT c.id, c.text FROM syscomments c INNER JOIN sysobjects o ON c.id = o.id WHERE o.name = 'encrypt_this'

標簽:延邊 合肥 三明 澳門 嘉興 保定 晉城 日照

巨人網絡通訊聲明:本文標題《SQL 存儲過程基礎語法之一》,本文關鍵詞  SQL,存儲,過程,基礎,語法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL 存儲過程基礎語法之一》相關的同類信息!
  • 本頁收集關于SQL 存儲過程基礎語法之一的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲欧美另类图片小说| 日韩精品一区二区三区视频在线观看| 国产日韩av一区| 极品美女销魂一区二区三区| 亚洲图片欧美色图| 国模少妇一区二区三区| 欧美午夜精品一区| 国产成人亚洲综合a∨婷婷| 日本韩国欧美一区| 欧美一区二区视频在线观看2020| 中文字幕一区二区三中文字幕| 91麻豆高清视频| 欧美日韩成人一区二区| 奇米影视一区二区三区| 国产原创一区二区| 欧美日韩国产中文| 亚洲国产综合视频在线观看| 久久成人免费网| 91免费视频网址| 亚洲精品国产一区二区精华液| 91麻豆精品国产91久久久使用方法| 色一情一乱一乱一91av| 精品国产a毛片| 精品一区二区三区免费视频| 欧美一区二区日韩| 国产乱码一区二区三区| 日韩精品一区国产麻豆| 一区二区三区高清不卡| 欧美伊人久久久久久久久影院| 欧美国产精品中文字幕| 91亚洲永久精品| 亚洲国产婷婷综合在线精品| 欧美精品色综合| av网站免费线看精品| 婷婷久久综合九色综合绿巨人| 精品国产乱子伦一区| 在线亚洲免费视频| 国产美女视频91| 丝袜诱惑制服诱惑色一区在线观看 | 欧美精品乱码久久久久久| 午夜国产不卡在线观看视频| 91免费视频网| 成人av电影在线| 亚洲国产日韩a在线播放| 久久人人97超碰com| 一本大道久久a久久综合| 国产在线视频一区二区三区| 亚洲美女少妇撒尿| 亚洲欧洲色图综合| 亚洲国产精品黑人久久久| 久久麻豆一区二区| 中文字幕av一区 二区| 久久精品网站免费观看| 欧美一区二区三区免费在线看| 精品视频免费在线| 日韩一区二区电影网| 欧美日韩一区在线观看| 欧美在线小视频| 在线观看一区二区精品视频| 91福利精品第一导航| 欧美午夜片在线观看| 欧美伦理视频网站| 日韩一区二区在线免费观看| 欧美精品一区二区三区蜜桃| 日韩免费观看高清完整版| 精品黑人一区二区三区久久| 日韩欧美不卡在线观看视频| 久久综合中文字幕| 亚洲综合小说图片| 美女在线视频一区| 91在线高清观看| 欧美一区二区精美| 国产精品国产a| 久久99国产精品麻豆| 成人激情视频网站| 精品国内片67194| 一区二区成人在线视频| 国模一区二区三区白浆| 一本到不卡免费一区二区| 国产人久久人人人人爽| 日本视频中文字幕一区二区三区| 美女任你摸久久| 96av麻豆蜜桃一区二区| 亚洲二区在线视频| 午夜精品影院在线观看| 日韩中文字幕麻豆| gogogo免费视频观看亚洲一| 538prom精品视频线放| 中文在线资源观看网站视频免费不卡 | 日韩精品成人一区二区三区 | 91九色最新地址| 久久久久久久久免费| 久草在线在线精品观看| 欧美成人性战久久| 色综合久久久久久久久| 欧美性一二三区| 成人国产一区二区三区精品| 欧美日韩免费观看一区二区三区| 国内精品久久久久影院一蜜桃| 婷婷久久综合九色综合伊人色| 亚洲欧美综合网| 亚洲一区二区三区在线| 高清国产午夜精品久久久久久| 丁香婷婷综合色啪| 成人免费毛片嘿嘿连载视频| 777色狠狠一区二区三区| 免费日韩伦理电影| 久久影院午夜片一区| 国产成人精品免费看| 久久精品一区二区三区av| 久久99精品网久久| 国产日韩欧美精品电影三级在线| 国产午夜精品在线观看| 国产精品入口麻豆原神| 久久99国产精品免费| 日韩精品一区二区三区老鸭窝 | 亚洲精品视频一区| 91麻豆精品视频| 夜夜爽夜夜爽精品视频| 亚洲丝袜美腿综合| 亚洲成av人片在线观看无码| 亚洲国产高清在线| 7777精品伊人久久久大香线蕉的 | 精品免费国产二区三区| 一区二区在线观看免费视频播放| 久久成人av少妇免费| xfplay精品久久| 欧美—级在线免费片| 久久99日本精品| 精品久久久久久久一区二区蜜臀| 色婷婷av一区二区三区软件| av不卡免费电影| 91亚洲精品乱码久久久久久蜜桃| 欧美在线免费观看亚洲| 中文字幕第一区| 强制捆绑调教一区二区| 久久www免费人成看片高清| 欧美一区二区私人影院日本| 欧日韩精品视频| 欧美亚洲国产一区二区三区va | 亚洲国产经典视频| 亚洲国产高清不卡| 国产欧美va欧美不卡在线| 欧美日韩亚洲综合一区| 日本韩国欧美一区二区三区| 国产精品一区二区三区网站| 日本久久精品电影| 日本久久一区二区| 欧美激情艳妇裸体舞| 日韩电影在线一区二区三区| 久久国产视频网| jizz一区二区| 日韩一区二区三区av| 日韩免费高清视频| 国产精品一区二区果冻传媒| 国产成人日日夜夜| 日韩国产欧美在线观看| 国产日韩精品久久久| 一区二区三区鲁丝不卡| 美女在线观看视频一区二区| 国产精品国产三级国产aⅴ原创| 99久久99久久精品免费观看| 26uuu久久天堂性欧美| 亚洲三级在线看| 日韩综合在线视频| 日本大胆欧美人术艺术动态| 欧美精品一区二区三区四区| 精品一区二区三区久久久| 成人av午夜电影| 久久老女人爱爱| 国产精品自拍av| 欧美性受xxxx黑人xyx性爽| 26uuu精品一区二区在线观看| 成人高清免费在线播放| 色拍拍在线精品视频8848| 国产乱国产乱300精品| av成人免费在线观看| 精品久久久久久久久久久久久久久久久| 最新国产精品久久精品| 激情文学综合丁香| 91麻豆国产自产在线观看| 国产精品色呦呦| 免费看欧美女人艹b| 日韩欧美国产一区二区在线播放| 国产精品免费网站在线观看| 欧美人妇做爰xxxⅹ性高电影| 成人欧美一区二区三区黑人麻豆 | 蜜桃视频一区二区三区| 欧美男男青年gay1069videost| 欧美一区日本一区韩国一区| 欧美成人video| 国产精品女同一区二区三区| 成人激情免费网站| 91麻豆精品91久久久久久清纯| 国产乱码精品一品二品| 3751色影院一区二区三区| 久久国产精品一区二区| 91影视在线播放| 久久久久高清精品| 欧美日韩高清影院|