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

首頁 > 學院 > 開發設計 > 正文

ADO.NET在開發中的部分使用方法和技巧

2019-11-18 16:30:32
字體:
來源:轉載
供稿:網友

using System.Data; using System.Data.SqlClient; public DataTable RetrieveRowsWithDataTable() { using ( SqlConnection conn = new SqlConnection(connectionString) ) { conn.Open(); SqlCommand cmd = new SqlCommand("DATRetrieve使用 SqlAdapter 生成 DataSet 或 DataTable
 

1.創建一個 SqlCommand 對象以調用該存儲過程,并將其與一個 SqlConnection 對象(顯示)或連接字符串(不顯示)相關聯。

2.創建一個新的 SqlDataAdapter 對象并將其與 SqlCommand 對象相關聯。

3.創建一個 DataTable(也可以創建一個 DataSet)對象。使用構造函數參數來命名 DataTable。

4.調用 SqlDataAdapter 對象的 Fill 方法,用檢索到的行填充 DataSet 或 DataTable。

 

如何使用 SqlDataReader 來檢索多個行
以下代碼片段闡明了可檢索多個行的 SqlDataReader方法。

using System.IO;
using System.Data;
using System.Data.SqlClient;
public SqlDataReader RetrieveRowsWithDataReader()
{ SqlConnection conn = new SqlConnection( "server=(local);Integrated Security=SSPI;database=northwind");
SqlCommand cmd = new SqlCommand("DATRetrieveProducts", conn );
cmd.CommandType = CommandType.StoredProcedure;
try { conn.Open();
// Generate the reader. CommandBehavior.CloseConnection causes the // the connection to be closed when the reader object is closed
return( cmd.ExecuteReader( CommandBehavior.CloseConnection ) ); }
catch { conn.Close(); throw; } } // Display the product list using the console
private void DisplayProducts() { SqlDataReader reader = RetrieveRowsWithDataReader();
try { while (reader.Read()) { Console.WriteLine("{0} {1} {2}", reader.GetInt32(0).ToString(), reader.GetString(1) ); } }
finally { reader.Close(); // Also closes the connection due to the // CommandBehavior enum used when generating the reader } }
使用 SqlDataReader 檢索行
 

1.創建一個用來執行存儲過程的 SqlCommand 對象,并將其與一個 SqlConnection對象相關聯。

2.打開連接。

3.通過調用 SqlCommand 對象的 ExecuteReader方法創建一個 SqlDataReader對象。
 
4.
 要從流中讀取數據,請調用 SqlDataReader對象的 Read方法來檢索行,并使用類型化訪問器方法(如 GetInt32和 GetString方法)來檢索列值。
 
5.
 使用完讀取器后,請調用其 Close方法。
 

 

如何使用 xmlReader 檢索多個行
可以使用 SqlCommand對象來生成 XmlReader對象,后者可提供對 XML 數據的基于流的只進訪問。命令(通常為存儲過程)必須產生基于 XML 的結果集,對于 SQL Server 2000 而言,該結果集通常包含一個帶有有效 FOR XML子句的 SELECT語句。以下代碼片段闡明了該方法:

public void RetrieveAndDisplayRowsWithXmlReader() {
using( SqlConnection conn = new SqlConnection(connectionString) )
{; SqlCommand cmd = new SqlCommand("DATRetrieveProductsXML", conn );
cmd.CommandType = CommandType.StoredProcedure;
try { conn.Open();
XmlTextReader xreader = (XmlTextReader)cmd.ExecuteXmlReader();
while ( xreader.Read() ) { if ( xreader.Name == "PRODUCTS" ) { string strOutput = xreader.GetAttribute("ProductID");
strOutput += " "; strOutput += xreader.GetAttribute("ProductName");
Console.WriteLine( strOutput ); } } xreader.Close();
// XmlTextReader does not support IDisposable so it can't be // used within a using keyWord } }
上述代碼使用了以下存儲過程:

CREATE PROCEDURE DATRetrieveProductsXML AS SELECT * FROM PRODUCTS FOR XML AUTO GO
使用 XmlReader 檢索 XML 數據
 

1.創建一個 SqlCommand 對象來調用可生成 XML 結果集的存儲過程(例如,在 SELECT語句中使用 FOR XML子句)。將該 SqlCommand對象與某個連接相關聯。

2.調用 SqlCommand 對象的 ExecuteXmlReader方法,并且將結果分配給只進 XmlTextReader對象。當您不需要對返回的數據進行任何基于 XML 的驗證時,這是應該使用的最快類型的 XmlReader對象。

3.使用 XmlTextReader 對象的 Read方法來讀取數據。

如何使用存儲過程輸出參數來檢索單個行
借助于命名的輸出參數,可以調用在單個行內返回檢索到的數據項的存儲過程。以下代碼片段使用存儲過程來檢索 Northwind 數據庫的 Products 表中包含的特定產品的產品名稱和單價。

void GetProductDetails( int ProductID, out string ProductName, out decimal UnitPrice )
{ using( SqlConnection conn = new SqlConnection( "server=(local);Integrated Security=SSPI;database=Northwind") )
{ // Set up the command object used to execute the stored proc SqlCommand cmd = new SqlCommand( "DATGetProductDetailsSPOutput", conn )
cmd.CommandType = CommandType.StoredProcedure;
// Establish stored proc parameters.
// @ProductID int INPUT
// @ProductName nvarchar(40) OUTPUT
// @UnitPrice money OUTPUT
// Must explicitly set the direction of output parameters SqlParameter paramProdID = cmd.Parameters.Add( "@ProductID", ProductID );
paramProdID.Direction = ParameterDirection.Input; SqlParameter paramProdName = cmd.Parameters.Add( "@ProductName", SqlDbType.VarChar, 40 );
paramProdName.Direction = ParameterDirection.Output; SqlParameter paramUnitPrice = cmd.Parameters.Add( "@UnitPrice", SqlDbType.Money );
paramUnitPrice.Direction = ParameterDirection.Output; conn.Open();
// Use ExecuteNonQuery to run the command.
// Although no rows are returned any mapped output parameters
// (and potentially return values) are populated cmd.ExecuteNonQuery( );
// Return output parameters from stored proc ProductName = paramProdName.Value.ToString();
UnitPrice = (decimal)paramUnitPrice.Value; } }
使用存儲過程輸出參數來檢索單個行
 

1.創建一個 SqlCommand 對象并將其與一個 SqlConnection對象相關聯。

2.通過調用 SqlCommand 的 Parameters集合的 Add方法來設置存儲過程參數。默認情況下,參數都被假設為輸入參數,因此必須顯式設置任何輸出參數的方向。

注一種良好的習慣做法是顯式設置所有參數(包括輸入參數)的方向。

3.打開連接。

4.調用 SqlCommand 對象的 ExecuteNonQuery方法。這將填充輸出參數(并可能填充返回值)。

5.通過使用 Value 屬性,從適當的 SqlParameter對象中檢索輸出參數。

6.關閉連接。

 

上述代碼片段調用了以下存儲過程。

CREATE PROCEDURE DATGetProductDetailsSPOutput
@ProductID int,
@ProductName nvarchar(40) OUTPUT,
@UnitPrice money OUTPUT AS SELECT @ProductName = ProductName,
@UnitPrice = UnitPrice FROM Products WHERE ProductID = @ProductID GO
如何使用 SqlDataReader 來檢索單個行
可以使用 SqlDataReader對象來檢索單個行,尤其是可以從返回的數據流中檢索需要的列值。以下代碼片段對此進行了說明。

void GetProductDetailsUsingReader( int ProductID, out string ProductName, out decimal UnitPrice )
{ using( SqlConnection conn = new SqlConnection( "server=(local);
Integrated Security=SSPI;database=Northwind") ) {
// Set up the command object used to execute the stored proc SqlCommand cmd = new SqlCommand( "DATGetProductDetailsReader", conn );
cmd.CommandType = CommandType.StoredProcedure;
// Establish stored proc parameters.
// @ProductID int INPUT SqlParameter paramProdID = cmd.Parameters.Add( "@ProductID", ProductID );
paramProdID.Direction = ParameterDirection.Input;
conn.Open();
using( SqlDataReader reader = cmd.ExecuteReader() ) { if( reader.Read() )
// Advance to the one and only row {
// Return output parameters from returned data stream ProductName = reader.GetString(0);
UnitPrice = reader.GetDecimal(1);
} } } }
使用 SqlDataReader 對象來返回單個行
 

1.建立 SqlCommand 對象。

2.打開連接。

3.調用 SqlDataReader 對象的 ExecuteReader方法。

4.通過 SqlDataReader 對象的類型化訪問器方法(在這里,為 GetString和 GetDecimal)來檢索輸出參數。

 

上述代碼片段調用了以下存儲過程。

CREATE PROCEDURE DATGetProductDetailsReader
@ProductID int AS SELECT ProductName, UnitPrice FROM Products WHERE ProductID =
@ProductID GO
如何使用 ExecuteScalar 來檢索單個項
ExecuteScalar方法專門適用于僅返回單個值的查詢。如果查詢返回多個列和/或行,ExecuteScalar將只返回第一行的第一列。

以下代碼說明了如何查找與特定產品 ID 相對應的產品名稱:

void GetProductNameExecuteScalar( int ProductID, out string ProductName )
{ using( SqlConnection conn = new SqlConnection( "server=(local);Integrated Security=SSPI;database=northwind") )
{ SqlCommand cmd = new SqlCommand("LookupProductNameScalar", conn );
cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.Add("@ProductID", ProductID );
conn.Open();
ProductName = (string)cmd.ExecuteScalar();
} }
使用 ExecuteScalar 來檢索單個項
 

1.建立一個 SqlCommand 對象來調用存儲過程。

2.打開連接。

3.調用 ExecuteScalar 方法。注意,該方法返回一個對象類型。它包含檢索到的第一列的值,并且必須轉化為適當的類型。

4.關閉連接。

 

上述代碼使用了以下存儲過程:

CREATE PROCEDURE LookupProductNameScalar
@ProductID int AS SELECT TOP 1 ProductName FROM Products WHERE ProductID =
@ProductID GO
如何使用存儲過程輸出或返回參數來檢索單個項
可以使用存儲過程輸出或返回參數來查找單個值。以下代碼闡明了輸出參數的用法:

void GetProductNameUsingSPOutput( int ProductID, out string ProductName )
{ using( SqlConnection conn = new SqlConnection( "server=(local);Integrated Security=SSPI;database=northwind") )
{ SqlCommand cmd = new SqlCommand("LookupProductNameSPOutput", conn );
cmd.CommandType = CommandType.StoredProcedure;
SqlParameter paramProdID = cmd.Parameters.Add("@ProductID", ProductID );
ParamProdID.Direction = ParameterDirection.Input;
SqlParameter paramPN = cmd.Parameters.Add("@ProductName", SqlDbType.VarChar, 40 );
paramPN.Direction = ParameterDirection.Output; conn.Open();
cmd.ExecuteNonQuery();
ProductName = paramPN.Value.ToString();
} }
使用存儲過程輸出參數來檢索單個值
 

1.建立一個 SqlCommand 對象來調用存儲過程。

2.通過將 SqlParameters 添加到 SqlCommand的 Parameters集合中,設置任何輸入參數和單個輸出參數。

3.打開連接。

4.調用 SqlCommand 對象的 ExecuteNonQuery方法。

5.關閉連接。

6.通過使用輸出 SqlParameter 的 Value屬性來檢索輸出值。

 

上述代碼使用了以下存儲過程。

@ProductID int,
@ProductName nvarchar(40) OUTPUT AS SELECT
@ProductName = ProductName FROM Products WHERE ProductID = @ProductID GO
以下代碼闡明了如何使用返回值來指明是否存在特定行。從編碼角度來看,這類似于使用存儲過程輸出參數,不同之處在于必須將 SqlParameter方向顯式設置為 ParameterDirection.ReturnValue。

bool CheckProduct( int ProductID )
{ using( SqlConnection conn = new SqlConnection( "server=(local);
Integrated Security=SSPI;database=northwind") )
{ SqlCommand cmd = new SqlCommand("CheckProductSP", conn );
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@ProductID", ProductID );
SqlParameter paramRet = cmd.Parameters.Add("@ProductExists", SqlDbType.Int );
paramRet.Direction = ParameterDirection.ReturnValue; conn.Open(); cmd.ExecuteNonQuery(); }
return (int)paramRet.Value == 1; }
通過使用存儲過程返回值來檢查是否存在特定行
 

1.建立一個 SqlCommand 對象來調用存儲過程。

2.設置一個輸入參數,該參數含有要訪問的行的主鍵值。

3.設置單個返回值參數。將一個 SqlParameter 對象添加到 SqlCommand的 Parameters集合中,并將其方向設置為 ParameterDirection.ReturnValue。

4.打開連接。

5.調用 SqlCommand 對象的 ExecuteNonQuery方法。

6.關閉連接。

7.通過使用返回值 SqlParameter 的 Value屬性來檢索返回值。

 

上述代碼使用了以下存儲過程。

CREATE PROCEDURE CheckProductSP
@ProductID int AS IF EXISTS( SELECT ProductID FROM Products WHERE ProductID =
@ProductID )
return 1 ELSE return 0 GO
如何使用 SqlDataReader 來檢索單個項
可以使用 SqlDataReader對象并通過調用命令對象的 ExecuteReader方法來獲取單個輸出值。這要求編寫稍微多一點的代碼,因為必須調用 SqlDataReader Read 方法,然后通過該讀取器的訪問器方法之一來檢索需要的值。以下代碼闡明了 SqlDataReader對象的用法。

bool CheckProductWithReader( int ProductID )
{ using( SqlConnection conn = new SqlConnection( "server=(local);
Integrated Security=SSPI;database=northwind") )
{ SqlCommand cmd = new SqlCommand("CheckProductExistsWithCount", conn );
cmd.CommandType = CommandType.StoredProcedure;
cmd.Parameters.Add("@ProductID", ProductID );
cmd.Parameters["@ProductID"].Direction = ParameterDirection.Input; conn.Open();
using( SqlDataReader reader = cmd.ExecuteReader( CommandBehavior.SingleResult ) )
{ if( reader.Read() ) { return (reader.GetInt32(0) >0); } return false; } }
上述代碼采用了以下存儲過程。

CREATE PROCEDURE CheckProductExistsWithCount @ProductID int AS SELECT COUNT(*) FROM Products WHERE ProductID = @ProductID GO
如何編寫 ADO.NET 手動事務處理代碼
以下代碼顯示了如何充分利用 SQL Server .NET 數據提供程序所提供的事務處理支持,通過事務來保護資金轉帳操作。該操作在同一數據庫中的兩個帳戶之間轉移資金。

public void TransferMoney( string toAccount, string fromAccount, decimal amount ) {
using ( SqlConnection conn = new SqlConnection( "server=(local);Integrated Security=SSPI;database=SimpleBank" ) )
{ SqlCommand cmdCredit = new SqlCommand("Credit", conn );
cmdCredit.CommandType = CommandType.StoredProcedure;
cmdCredit.Parameters.Add( new SqlParameter("@AccountNo", toAccount) );
cmdCredit.Parameters.Add( new SqlParameter("@Amount", amount ));
SqlCommand cmdDebit = new SqlCommand("Debit", conn );
cmdDebit.CommandType = CommandType.StoredProcedure; cmdDebit.Parameters.Add( new SqlParameter("@AccountNo", fromAccount) );
cmdDebit.Parameters.Add( new SqlParameter("@Amount", amount ));
conn.Open();
// Start a new transaction using ( SqlTransaction trans = conn.BeginTransaction() ) {
// Associate the two command objects with the same transaction cmdCredit.Transaction = trans;
cmdDebit.Transaction = trans;
try { cmdCredit.ExecuteNonQuery();
cmdDebit.ExecuteNonQuery(); // Both commands (credit and debit) were successful trans.Commit(); }
catch( Exception ex ) {
// transaction failed trans.Rollback();
// log exception details . . .
throw ex; } } } }
如何使用 Transact-SQL 執行事務處理
以下存儲過程闡明了如何在 Transact-SQL 存儲過程內部執行事務性資金轉帳操作。

CREATE PROCEDURE MoneyTransfer
@FromAccount char(20),
@ToAccount char(20),
@Amount money AS BEGIN TRANSACTION -- PERFORM DEBIT OperaTION UPDATE Accounts SET Balance = Balance -
@Amount WHERE AccountNumber = @FromAccount IF RowCount = 0 BEGIN RAISERROR('Invalid From Account Number', 11, 1)
GOTO ABORT END DECLARE
@Balance money SELECT @Balance = Balance FROM ACCOUNTS
WHERE AccountNumber = @FromAccount IF @BALANCE
0 BEGIN RAISERROR('Insufficient funds', 11, 1)
GOTO ABORT END -- PERFORM CREDIT OPERATION UPDATE Accounts SET Balance = Balance + @Amount WHERE AccountNumber = @ToAccount
IF RowCount = 0 BEGIN RAISERROR('Invalid To Account Number', 11, 1) GOTO ABORT END COMMIT TRANSACTION RETURN 0 ABORT: ROLLBACK TRANSACTION GO
該存儲過程使用 BEGIN TRANSACTION、COMMIT TRANSACTION 和 ROLLBACK TRANSACTION 語句來手動控制該事務。

如何編寫事務性 .NET 類
以下示例代碼顯示了三個服務性 .NET 托管類,這些類經過配置以執行自動事務處理。每個類都使用 Transaction屬性進行了批注,該屬性的值確定是否應該啟動新的事務流,或者該對象是否應該共享其直接調用方的事務流。這些組件協同工作來執行銀行資金轉帳任務。Transfer類被使用 RequiresNew事務屬性進行了配置,而 Debit和 Credit被使用 Required進行了配置。結果,所有這三個對象在運行時都將共享同一事務。

using System;
using System.EnterpriseServices;
[Transaction(TransactionOption.RequiresNew)]
public class Transfer : ServicedComponent { [AutoComplete]
public void Transfer( string toAccount, string fromAccount, decimal amount ) {
try { // Perform the debit operation Debit debit = new Debit();
debit.DebitAccount( fromAccount, amount );
// Perform the credit operation Credit credit = new Credit();
credit.CreditAccount( toAccount, amount ); }
catch( SqlException sqlex ) {
// Handle and log exception details
// Wrap and propagate the exception throw new TransferException( "Transfer Failure", sqlex ); } } }
[Transaction(TransactionOption.Required)]
public class Credit : ServicedComponent { [AutoComplete]
public void CreditAccount( string account, decimal amount ) { try {
using( SqlConnection conn = new SqlConnection( "Server=(local); Integrated Security=SSPI";
database="SimpleBank") ) {
SqlCommand cmd = new SqlCommand("Credit", conn );
cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.Add( new SqlParameter("@AccountNo", account) );
cmd.Parameters.Add( new SqlParameter("@Amount", amount ));
conn.Open();
cmd.ExecuteNonQuery(); } } }
catch( SqlException sqlex ){
// Log exception details here throw;
// Propagate exception } } [Transaction(TransactionOption.Required)]
public class Debit : ServicedComponent { public void DebitAccount( string account, decimal amount ) {
try { using( SqlConnection conn = new SqlConnection( "Server=(local);
Integrated Security=SSPI";
database="SimpleBank") ) { SqlCommand cmd = new SqlCommand("Debit", conn );
cmd.CommandType = CommandType.StoredProcedure; cmd.Parameters.Add( new SqlParameter("@AccountNo", account) );
cmd.Parameters.Add( new SqlParameter("@Amount", amount )); conn.Open(); cmd.ExecuteNonQuery(); } }
catch (SqlException sqlex) {
// Log exception details here throw;
// Propagate exception back to caller } } }


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品在线免费| 国产视频福利一区| 国产一区二区日韩精品欧美精品| 国产精品亚洲网站| 亚洲精品www久久久| 国产成人欧美在线观看| 欧美激情欧美狂野欧美精品| 国产欧美日韩亚洲精品| 在线观看免费高清视频97| 欧美日韩亚洲精品内裤| 欧美大片在线看免费观看| 欧美日韩在线免费观看| 国内精品一区二区三区| 国产精品自拍偷拍视频| 国外色69视频在线观看| 国产精品久久久久久超碰| 国产精品爱久久久久久久| 亲爱的老师9免费观看全集电视剧| 精品亚洲aⅴ在线观看| 一区二区三区视频免费在线观看| 亚洲美女又黄又爽在线观看| 91精品啪在线观看麻豆免费| 欧美成人午夜激情| 91夜夜未满十八勿入爽爽影院| 午夜精品一区二区三区在线播放| 欧美大人香蕉在线| 国产日本欧美一区二区三区| 亚洲韩国欧洲国产日产av| 992tv在线成人免费观看| 久久久精品网站| 国产精品视频久久久久| 中日韩美女免费视频网站在线观看| 欧美老少配视频| 国产精品久久久久久久久久东京| 国产精品狼人色视频一区| 日韩女在线观看| 欧美一级免费看| 欧美成人亚洲成人日韩成人| 亚洲成人免费网站| 亚洲一区二区福利| 91九色视频导航| 日韩av网站在线| 欧美日产国产成人免费图片| 欧美日韩一区二区三区在线免费观看| 最新的欧美黄色| 2021国产精品视频| 日韩av片永久免费网站| 97精品欧美一区二区三区| 久久久999成人| 亚洲精品午夜精品| 国产精品福利在线| 精品国偷自产在线| 日韩欧美在线观看| 久久频这里精品99香蕉| 欧美视频专区一二在线观看| 久久久国产一区| 亚洲成在人线av| 高跟丝袜一区二区三区| 精品国产乱码久久久久酒店| 日韩在线播放一区| 午夜免费久久久久| 日韩中文在线中文网三级| 国产精品自在线| 欧洲精品在线视频| 亚洲免费一级电影| 精品网站999www| 91精品在线播放| 91久久精品视频| 亚洲自拍偷拍网址| 日韩电影中文 亚洲精品乱码| 久久视频免费观看| 国产精品一二区| 亚洲片av在线| 自拍偷拍亚洲欧美| 亚洲一区二区三区乱码aⅴ| 国产精品三级网站| 国产成人精品免高潮在线观看| 性欧美暴力猛交69hd| 亚洲精品国产精品乱码不99按摩| 国产一区二区丝袜高跟鞋图片| 狠狠做深爱婷婷久久综合一区| 久久精品国产亚洲7777| 亚洲精品视频在线播放| 国产精品96久久久久久又黄又硬| 91亚洲永久免费精品| 日韩福利伦理影院免费| 国产精品网红福利| 亚洲美女在线视频| 青草青草久热精品视频在线网站| 97avcom| 欧美高清在线视频观看不卡| 日本精品久久久久久久| 欧美视频免费在线| 中文字幕日韩综合av| 亚洲一区二区中文字幕| 久久亚洲精品一区| 久久精品小视频| 精品国产一区二区三区在线观看| 成人国产精品免费视频| 亚洲精品美女在线观看播放| 亚洲成人av中文字幕| 中文字幕少妇一区二区三区| 久久99国产精品久久久久久久久| 亚洲大胆人体av| 66m—66摸成人免费视频| xxx成人少妇69| 成人444kkkk在线观看| 欧美亚洲在线观看| 91免费视频国产| 日韩在线观看免费全集电视剧网站| 中文字幕日韩在线播放| 人体精品一二三区| 国产偷国产偷亚洲清高网站| 欧美高清电影在线看| 国产成人福利视频| 欧美在线视频观看免费网站| 亚洲福利视频网站| 日韩欧美视频一区二区三区| 黄色一区二区三区| 日韩亚洲在线观看| 91美女片黄在线观| 91精品国产精品| 欧美一区二区三区……| 亚洲国产另类 国产精品国产免费| 亚洲r级在线观看| 精品呦交小u女在线| 久久人人爽亚洲精品天堂| 欧美网站在线观看| 欧洲亚洲免费视频| 国产精品视频中文字幕91| 国产精品久久久久久久久久小说| 精品成人久久av| 日韩亚洲成人av在线| 高清欧美性猛交xxxx| 日韩国产中文字幕| 亚洲视频免费一区| 亚洲人线精品午夜| 欧美精品九九久久| 亚洲全黄一级网站| 欧美亚洲激情在线| 91视频免费在线| 日韩动漫免费观看电视剧高清| 欧美专区日韩视频| 中文字幕日韩欧美在线| 久久久国产精品视频| www.xxxx精品| 亚洲一区二区黄| 国产欧美欧洲在线观看| 欧美一级电影在线| 九九精品在线视频| 3344国产精品免费看| 午夜精品久久久久久久久久久久久| 九九热这里只有在线精品视| 国产va免费精品高清在线观看| 欧美国产日韩视频| 欧美成aaa人片在线观看蜜臀| 欧美日韩国产页| 国产精品午夜国产小视频| 一区二区三区美女xx视频| 91精品国产777在线观看| 精品亚洲夜色av98在线观看| 亚洲aa中文字幕| 欧美美女18p| 久久免费精品日本久久中文字幕|