日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程语言 > asp.net >内容正文

asp.net

ADO.NET实用经验 转载

發(fā)布時(shí)間:2024/4/15 asp.net 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ADO.NET实用经验 转载 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

ADO.NET作為微軟最實(shí)用的數(shù)據(jù)訪問(wèn)技術(shù),已經(jīng)在企業(yè)開發(fā)中得到了廣泛的應(yīng)用。對(duì)于一線的開發(fā)人員來(lái)說(shuō),掌握基本的概念和技術(shù)之后,提高應(yīng)用水平和解決實(shí)際問(wèn)題的最有效手段,莫過(guò)于相互交流彼此的最佳時(shí)間經(jīng)驗(yàn)經(jīng)驗(yàn)。在這篇文章中,兩位ADO.NET專家向讀者毫無(wú)保留地、詳盡地介紹了很多實(shí)用經(jīng)驗(yàn)。

  簡(jiǎn)介

  本文為您提供了在Microsoft ADO.NET應(yīng)用程序中實(shí)現(xiàn)和獲得最佳性能、可伸縮性以及功能的最佳解決方案;同時(shí)也講述了使用ADO.NET中可用對(duì)象的最佳實(shí)踐;并提出一些有助于優(yōu)化ADO.NET應(yīng)用程序設(shè)計(jì)的建議。

  .NET框架數(shù)據(jù)提供程序

  .NET框架中的數(shù)據(jù)提供程序(Data Provider)在應(yīng)用程序和數(shù)據(jù)源之間起到橋梁作用。.NET框架數(shù)據(jù)提供程序能夠從數(shù)據(jù)源中返回查詢結(jié)果、對(duì)數(shù)據(jù)源執(zhí)行命令、將DataSet中的更改傳播給數(shù)據(jù)源。本文包括有關(guān)哪個(gè).NET框架數(shù)據(jù)提供程序是最適合您需要的一些技巧。

  使用哪個(gè).NET框架數(shù)據(jù)提供程序?

  為了使您的應(yīng)用程序獲得最佳性能,請(qǐng)使用最適合您的數(shù)據(jù)源的.NET框架數(shù)據(jù)提供程序。有許多數(shù)據(jù)提供程序可供您的應(yīng)用程序選用。

  連接到SQL Server 7.0或更高版本

  為了在連接到Microsoft SQL Server 7.0或更高版本時(shí)獲得最佳性能,請(qǐng)使用SQL Server .NET數(shù)據(jù)提供程序。SQL Server .NET數(shù)據(jù)提供程序的設(shè)計(jì)目的就在于不通過(guò)任何附加技術(shù)層就可以直接訪問(wèn)SQL Server。

  連接到ODBC數(shù)據(jù)源

  ODBC .NET數(shù)據(jù)提供程序可在Microsoft.Data.ODBC命名空間中找到,它的體系結(jié)構(gòu)與用于SQL Server和OLE DB的.NET數(shù)據(jù)提供程序相同。ODBC .NET數(shù)據(jù)提供程序遵循命名約定-以“ODBC”為前綴(例如,OdbcConnection),并使用標(biāo)準(zhǔn)ODBC連接字符串。

  使用DataReader、DataSet、DataAdapter和DataView

  ADO.NET提供以下兩個(gè)對(duì)象,用于檢索關(guān)系數(shù)據(jù)并將其存儲(chǔ)在內(nèi)存中:DataSet和DataReader。DataSet提供一個(gè)內(nèi)存中數(shù)據(jù)的關(guān)系表示形式,一整套包括一些表在內(nèi)的數(shù)據(jù)(這些表包含數(shù)據(jù)、對(duì)數(shù)據(jù)進(jìn)行排序并約束數(shù)據(jù)),以及表之間的關(guān)系。DataReader提供一個(gè)來(lái)自數(shù)據(jù)庫(kù)的快速、僅向前、只讀數(shù)據(jù)流。

  當(dāng)使用DataSet時(shí),經(jīng)常會(huì)利用DataAdapter(也可能是CommandBuilder)與數(shù)據(jù)源進(jìn)行交互。當(dāng)使用DataSet時(shí),也可以利用DataView對(duì)DataSet中的數(shù)據(jù)應(yīng)用排序和篩選。也可以從DataSet繼承,創(chuàng)建強(qiáng)類型DataSet,用于將表、行和列作為強(qiáng)類型對(duì)象屬性公開。

  下列主題包括的信息涉及:使用DataSet或DataReader的最佳時(shí)機(jī)、如何優(yōu)化訪問(wèn)它們所包含數(shù)據(jù)、以及如何優(yōu)化使用DataAdapter(包括CommandBuilder)和DataView的技巧。

  DataSet與DataReader

  當(dāng)設(shè)計(jì)應(yīng)用程序時(shí),要考慮應(yīng)用程序所需功能的等級(jí),以確定使用DataSet或者是DataReader。

  要通過(guò)應(yīng)用程序執(zhí)行以下操作,就要使用DataSet:

  1) 在結(jié)果的多個(gè)離散表之間進(jìn)行導(dǎo)航。
? [轉(zhuǎn)自:51item.net]?
  2) 操作來(lái)自多個(gè)數(shù)據(jù)源(例如,來(lái)自多個(gè)數(shù)據(jù)庫(kù)、一個(gè)XML文件和一個(gè)電子表格的混合數(shù)據(jù))的數(shù)據(jù)。

  3) 在各層之間交換數(shù)據(jù)或使用XML Web服務(wù)。與DataReader不同的是,DataSet能傳遞給遠(yuǎn)程客戶端。

  4) 重用同樣的記錄集合,以便通過(guò)緩存獲得性能改善(例如排序、搜索或篩選數(shù)據(jù))。

  5) 每條記錄都需要執(zhí)行大量處理。對(duì)使用DataReader返回的每一行進(jìn)行擴(kuò)展處理會(huì)延長(zhǎng)服務(wù)于DataReader的連接的必要時(shí)間,這影響了性能。

  6) 使用XML操作對(duì)數(shù)據(jù)進(jìn)行操作,例如可擴(kuò)展樣式表語(yǔ)言轉(zhuǎn)換(XSLT轉(zhuǎn)換)或XPath查詢。

  對(duì)于下列情況,要在應(yīng)用程序中使用DataReader:

  1) 不需要緩存數(shù)據(jù)。

  2) 要處理的結(jié)果集太大,內(nèi)存中放不下。

  3) 一旦需要以僅向前、只讀方式快速訪問(wèn)數(shù)據(jù)。

  注填充DataSet時(shí),DataAdapter使用DataReader。因此,使用DataAdapter取代DataSet提升的性能表現(xiàn)為節(jié)省了DataSet占用內(nèi)存和填充DataSet需要的循環(huán)。一般來(lái)說(shuō),此性能提升只是象征性的,因此,設(shè)計(jì)決策應(yīng)以所需功能為基礎(chǔ)。

  使用強(qiáng)類型DataSet的好處

  DataSet的另一個(gè)好處是可被繼承以創(chuàng)建一個(gè)強(qiáng)類型DataSet。強(qiáng)類型DataSet的好處包括設(shè)計(jì)時(shí)類型檢查,以及Microsoft Visual Studio.NET用于強(qiáng)類型DataSet語(yǔ)句結(jié)束所帶來(lái)的好處。修改了DataSet的架構(gòu)或關(guān)系結(jié)構(gòu)后,就可以創(chuàng)建一個(gè)強(qiáng)類型DataSet,將行和列作為對(duì)象的屬性公開,而不是作為集合中的項(xiàng)公開。例如,不公開客戶表中行的姓名列,而公開Customer對(duì)象的Name屬性。類型化DataSet從DataSet類派生,因此不會(huì)犧牲DataSet的任何功能。也就是說(shuō),類型化DataSet仍能遠(yuǎn)程訪問(wèn),并作為數(shù)據(jù)綁定控件(例如DataGrid)的數(shù)據(jù)源提供。如果架構(gòu)事先不可知,仍能受益于通用DataSet的功能,但卻不能受益于強(qiáng)類型DataSet的附加功能。

  處理強(qiáng)類型DataSet中的空引用

  使用強(qiáng)類型DataSet時(shí),可以使用DataSet的XML架構(gòu)定義語(yǔ)言(XSD)架構(gòu)來(lái)確保強(qiáng)類型DataSet可以正確處理空引用。nullValue標(biāo)識(shí)符使您可用一個(gè)指定的值String.Empty代替DBNull、保留空引用或引發(fā)異常。選擇哪個(gè)選項(xiàng)取決于應(yīng)用程序的上下文。默認(rèn)情況下,如果遇到空引用,就會(huì)引發(fā)異常。

  刷新DataSet中的數(shù)據(jù)

  如果想用服務(wù)器上的更新值刷新DataSet中的值,就使用DataAdapter.Fill。如果有在DataTable上定義的主鍵,DataAdapter.Fill會(huì)根據(jù)主鍵進(jìn)行新行匹配,并且當(dāng)更改到現(xiàn)有行時(shí)應(yīng)用服務(wù)器上的值。即使刷新之前修改了這些數(shù)據(jù),刷新行的RowState仍被設(shè)置為Unchanged。注意,如果沒(méi)有為DataTable定義主鍵,DataAdapter.Fill就用可能重復(fù)的主鍵值添加新行。

  如果想用來(lái)自服務(wù)器的當(dāng)前值刷新表,并同時(shí)保留對(duì)表中的行所做的任何更改,必須首先用DataAdapter.Fill填充表,并填充一個(gè)新的DataTable,然后用preserveChanges值true將DataTable合并到DataSet之中。


在DataSet中搜索數(shù)據(jù)

  在DataSet中查詢與特定條件相匹配的行時(shí),可以利用基于索引的查找提高搜索性能。當(dāng)將PrimaryKey值賦給DataTable時(shí),會(huì)創(chuàng)建一個(gè)索引。當(dāng)給DataTable創(chuàng)建DataView時(shí),也會(huì)創(chuàng)建一個(gè)索引。下面是一些利用基于索引進(jìn)行查找的技巧。

  1) 如果對(duì)組成DataTable的PrimaryKey的列進(jìn)行查詢,要使用DataTable.Rows.Find而不是DataTable.Select。

  2) 對(duì)于涉及到非主鍵列的查詢,可以使用DataView為數(shù)據(jù)的多個(gè)查詢提高性能。當(dāng)將排序順序應(yīng)用到DataView時(shí),就會(huì)建立一個(gè)搜索時(shí)使用的索引。DataView公開Find和FindRows方法,以便查詢基礎(chǔ)DataTable中的數(shù)據(jù)。

  3) 如果不需要表的排序視圖,仍可以通過(guò)為DataTable創(chuàng)建DataView來(lái)利用基于索引的查找。注意,只有對(duì)數(shù)據(jù)執(zhí)行多個(gè)查詢操作時(shí),這樣才會(huì)帶來(lái)好處。如果只執(zhí)行單一查詢,創(chuàng)建索引所需要的處理就會(huì)降低使用索引所帶來(lái)的性能提升。

  DataView構(gòu)造

  如果創(chuàng)建了DataView,并且修改了Sort、RowFilter或RowStateFilter屬性,DataView就會(huì)為基礎(chǔ)DataTable中的數(shù)據(jù)建立索引。創(chuàng)建DataView對(duì)象時(shí),要使用DataView構(gòu)造函數(shù),它用Sort、RowFilter和RowStateFilter值作為構(gòu)造函數(shù)參數(shù)(與基礎(chǔ)DataTable一起)。結(jié)果是創(chuàng)建了一次索引。創(chuàng)建一個(gè)“空”DataView并隨后設(shè)置Sort、RowFilter或RowStateFilter屬性,會(huì)導(dǎo)致索引至少創(chuàng)建兩次。

  分頁(yè)

  ADO.NET可以顯式控制從數(shù)據(jù)源中返回什么樣的數(shù)據(jù),以及在DataSet中本地緩存多少數(shù)據(jù)。對(duì)查詢結(jié)果的分頁(yè)沒(méi)有唯一的答案,但下面有一些設(shè)計(jì)應(yīng)用程序時(shí)應(yīng)該考慮的技巧。

  1) 避免使用帶有startRecord和maxRecords值的DataAdapter.Fill重載。當(dāng)以這種方式填充DataSet時(shí),只有maxRecords參數(shù)(從startRecord參數(shù)標(biāo)識(shí)的記錄開始)指定的記錄數(shù)量用于填充DataSet,但無(wú)論如何總是返回完整的查詢。這就會(huì)引起不必要的處理,用于讀取“不需要的”記錄;而且為了返回附加記錄,會(huì)耗盡不必要的服務(wù)器資源。

  2) 用于每次只返回一頁(yè)記錄的技術(shù)是創(chuàng)建SQL語(yǔ)句,將WHERE子句以及ORDER BY子句和TOP謂詞組合起來(lái)。此技術(shù)取決于存在一種可唯一標(biāo)識(shí)每一行的辦法。當(dāng)瀏覽下一頁(yè)記錄時(shí),修改WHERE子句使之包含所有唯一標(biāo)識(shí)符大于當(dāng)前頁(yè)最后一個(gè)唯一標(biāo)識(shí)符的記錄。當(dāng)瀏覽上一頁(yè)記錄時(shí),修改WHERE子句使之返回所有唯一標(biāo)識(shí)符小于當(dāng)前頁(yè)第一個(gè)唯一標(biāo)識(shí)符的記錄。兩種查詢都只返回記錄的TOP頁(yè)。當(dāng)瀏覽上一頁(yè)時(shí),需要以降序?yàn)榻Y(jié)果排序。這將有效地返回查詢的最后一頁(yè)(如果需要,顯示之前也許要重新排序結(jié)果)。

  3) 另一項(xiàng)每次只返回一頁(yè)記錄的技術(shù)是創(chuàng)建SQL語(yǔ)句,將TOP謂詞和嵌入式SELECT語(yǔ)句的使用結(jié)合在一起。此技術(shù)并不依賴于存在一種可唯一標(biāo)識(shí)每一行的辦法。使用這項(xiàng)技術(shù)的第一步是將所需頁(yè)的數(shù)量與頁(yè)大小相乘。然后將結(jié)果傳遞給SQL Query的TOP謂詞,該查詢以升序排列。再將此查詢嵌入到另一個(gè)查詢中,后者從降序排列的嵌入式查詢結(jié)果中選擇TOP頁(yè)大小。實(shí)質(zhì)上,返回的是嵌入式查詢的最后一頁(yè)。例如,要返回查詢結(jié)果的第三頁(yè)(頁(yè)大小是10),應(yīng)該書寫如下所示的命令:

SELECT TOP 10 * FROM?? [轉(zhuǎn)自:51item.net]?
(SELECT TOP 30 * FROM Customers ORDER BY Id ASC) AS Table1
ORDER BY Id DESC

  注意:從查詢中返回的結(jié)果頁(yè)以降序顯示。如果需要,應(yīng)該重新排序。

  1) 如果數(shù)據(jù)不經(jīng)常變動(dòng),可以在DataSet中本地維護(hù)一個(gè)記錄緩存,以此提高性能。例如,可以在本地DataSet中存儲(chǔ)10頁(yè)有用的數(shù)據(jù),并且只有當(dāng)用戶瀏覽超出緩存第一頁(yè)和最后一頁(yè)時(shí),才從數(shù)據(jù)源中查詢新數(shù)據(jù)。

  用架構(gòu)填充DataSet

  當(dāng)用數(shù)據(jù)填充DataSet時(shí),DataAdapter.Fill方法使用DataSet的現(xiàn)有架構(gòu),并使用從SelectCommand返回的數(shù)據(jù)填充它。如果在DataSet中沒(méi)有表名與要被填充的表名相匹配,Fill方法就會(huì)創(chuàng)建一個(gè)表。默認(rèn)情況下,Fill僅定義列和列類型。

  通過(guò)設(shè)置DataAdapter的MissingSchemaAction屬性,可以重寫Fill的默認(rèn)行為。例如,要讓Fill創(chuàng)建一個(gè)表架構(gòu),并且還包括主鍵信息、唯一約束、列屬性、是否允許為空、最大列長(zhǎng)度、只讀列和自動(dòng)增量的列,就要將DataAdapter.MissingSchemaAction指定為MissingSchemaAction.AddWithKey。或者,在調(diào)用DataAdapter.Fill前,可以調(diào)用DataAdapter.FillSchema來(lái)確保當(dāng)填充DataSet時(shí)架構(gòu)已到位。

  對(duì)FillSchema的調(diào)用會(huì)產(chǎn)生一個(gè)到服務(wù)器的額外行程,用于檢索附加架構(gòu)信息。為了獲得最佳性能,需要在調(diào)用Fill之前指定DataSet的架構(gòu),或者設(shè)置DataAdapter的MissingSchemaAction。

  使用CommandBuilder的最佳實(shí)踐

  假設(shè)SelectCommand執(zhí)行單一表SELECT,CommandBuilder就會(huì)以DataAdapter的SelectCommand屬性為基礎(chǔ)自動(dòng)生成DataAdapter的InsertCommand、UpdateCommand、和DeleteCommand屬性。下面是為獲得最佳性能而使用CommandBuilder的一些技巧。

  1) CommandBuilder的使用應(yīng)該限制在設(shè)計(jì)時(shí)或即席方案中。生成DataAdapter命令屬性所必需的處理會(huì)影響性能。如果預(yù)先知道INSERT/UPDATE/DELETE語(yǔ)句的內(nèi)容,就顯式設(shè)置它們。一個(gè)比較好的設(shè)計(jì)技巧是,為INSERT/UPDATE/DELETE命令創(chuàng)建存儲(chǔ)過(guò)程并顯式配置DataAdapter命令屬性以使用它們。

  2) CommandBuilder使用DataAdapter的SelectCommand屬性確定其他命令屬性的值。如果DataAdapter的SelectCommand本身曾經(jīng)更改過(guò),確保調(diào)用RefreshSchema以更新命令屬性。

  3) 如果DataAdapter命令屬性為空(命令屬性默認(rèn)情況下為空),CommandBuilder僅僅為它生成一條命令。如果顯式設(shè)置了命令屬性,CommandBuilder不會(huì)重寫它。如果希望CommandBuilder為以前已經(jīng)設(shè)置過(guò)的命令屬性生成命令,就將命令屬性設(shè)置為空。

  批處理SQL語(yǔ)句

  很多數(shù)據(jù)庫(kù)支持將多條命令合并或批處理成一條單一命令執(zhí)行。例如,SQL Server使您可以用分號(hào)“;”分隔命令。將多條命令合并成單一命令,能減少到服務(wù)器的行程數(shù),并提高應(yīng)用程序的性能。例如,可以將所有預(yù)定的刪除在應(yīng)用程序中本地存儲(chǔ)起來(lái),然后再發(fā)出一條批處理命令調(diào)用,從數(shù)據(jù)源刪除它們。
雖然這樣做確實(shí)能提高性能,但是,當(dāng)對(duì)DataSet中的數(shù)據(jù)更新進(jìn)行管理時(shí),可能會(huì)增加應(yīng)用程序的復(fù)雜性。要保持簡(jiǎn)單,可能要在DataSet中為每個(gè)DataTable創(chuàng)建一個(gè)DataAdapter。

用多個(gè)表填充DataSet

  如果使用批處理SQL語(yǔ)句檢索多個(gè)表并填充DataSet,第一個(gè)表用指定給Fill方法的表名命名。后面的表用指定給Fill方法的表名加上一個(gè)從1開始并且增量為1的數(shù)字命名。例如,如果運(yùn)行下面的代碼:

'Visual Basic
Dim da As SqlDataAdapter = New SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection)
Dim ds As DataSet = New DataSet()
da.Fill(ds, "Customers")

//C#
SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection);
DataSet ds = new DataSet();
da.Fill(ds, "Customers");?

  來(lái)自Customers表的數(shù)據(jù)放在名為“Customers”的DataTable中。來(lái)自O(shè)rders表的數(shù)據(jù)放在名為“Customers1”的DataTable中。

  填充完DataSet之后,可以很容易地將“Customers1”表的TableName屬性改為“Orders”。但是,后面的填充會(huì)導(dǎo)致“Customers”表被重新填充,而“Orders”表會(huì)被忽略,并創(chuàng)建另外一個(gè)“Customers1”表。為了對(duì)這種情況作出補(bǔ)救,創(chuàng)建一個(gè)DataTableMapping,將“Customers1”映射到“Orders”,并為其他后面的表創(chuàng)建其他的表映射。例如:

'Visual Basic
Dim da As SqlDataAdapter = New SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection)
da.TableMappings.Add("Customers1", "Orders")
Dim ds As DataSet = New DataSet()
da.Fill(ds, "Customers")

//C#
SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM Customers; SELECT * FROM Orders;", myConnection);
da.TableMappings.Add("Customers1", "Orders");
DataSet ds = new DataSet();
da.Fill(ds, "Customers");?

  使用DataReader

  下面是一些使用DataReader獲得最佳性能的技巧,同時(shí)還回答了一些關(guān)于使用DataReader的常見問(wèn)題。

  1) 在訪問(wèn)相關(guān)Command的任何輸出參數(shù)之前,必須關(guān)閉DataReader。

  2) 完成讀數(shù)據(jù)之后總是要關(guān)閉DataReader。如果使用Connection只是用于返回DataReader,那么關(guān)閉DataReader之后立刻關(guān)閉它。

  另外一個(gè)顯式關(guān)閉Connection的方法是將CommandBehavior.CloseConnection傳遞給ExecuteReader方法,以確保相關(guān)的連接在關(guān)閉DataReader時(shí)被關(guān)閉。如果從一個(gè)方法返回DataReader,而且不能控制DataReader或相關(guān)連接的關(guān)閉,則這樣做特別有用。

  1) 不能在層之間遠(yuǎn)程訪問(wèn)DataReader。DataReader是為已連接好的數(shù)據(jù)訪問(wèn)設(shè)計(jì)的。

  2) 當(dāng)訪問(wèn)列數(shù)據(jù)時(shí),使用類型化訪問(wèn)器,例如,GetString、GetInt32等。這使您不用進(jìn)行將GetValue返回的Object強(qiáng)制轉(zhuǎn)換成特定類型所需的處理。
? [轉(zhuǎn)自:51item.net]?
  3) 一個(gè)單一連接每次只能打開一個(gè)DataReader。在ADO中,如果打開一個(gè)單一連接,并且請(qǐng)求兩個(gè)使用只進(jìn)、只讀游標(biāo)的記錄集,那么ADO會(huì)在游標(biāo)生存期內(nèi)隱式打開第二個(gè)、未池化的到數(shù)據(jù)存儲(chǔ)區(qū)的連接,然后再隱式關(guān)閉該連接。對(duì)于ADO.NET,“秘密”完成的動(dòng)作很少。如果想在相同的數(shù)據(jù)存儲(chǔ)區(qū)上同時(shí)打開兩個(gè)DataReaders,就必須顯式創(chuàng)建兩個(gè)連接,每個(gè)DataReader一個(gè)。這是ADO.NET為池化連接的使用提供更多控制的一種方法。

  4) 默認(rèn)情況下,DataReader每次Read時(shí)都要將整行加載到內(nèi)存。這允許在當(dāng)前行內(nèi)隨機(jī)訪問(wèn)列。如果不需要這種隨機(jī)訪問(wèn),為了提高性能,就將CommandBehavior.SequentialAccess傳遞給ExecuteReader調(diào)用。這將DataReader的默認(rèn)行為更改為僅在請(qǐng)求時(shí)將數(shù)據(jù)加載到內(nèi)存。注意,CommandBehavior.SequentialAccess要求順序訪問(wèn)返回的列。也就是說(shuō),一旦讀過(guò)返回的列,就不能再讀它的值了。

  5) 如果已經(jīng)完成讀取來(lái)自DataReader的數(shù)據(jù),但仍然有大量掛起的未讀結(jié)果,就在調(diào)用DataReader的Close之前先調(diào)用Command的Cancel。調(diào)用DataReader的Close會(huì)導(dǎo)致在關(guān)閉游標(biāo)之前檢索掛起的結(jié)果并清空流。調(diào)用Command的Cancel會(huì)放棄服務(wù)器上的結(jié)果,這樣,DataReader在關(guān)閉的時(shí)候就不必讀這些結(jié)果。如果要從Command返回輸出參數(shù),還要調(diào)用Cancel放棄它們。如果需要讀取任何輸出參數(shù),不要調(diào)用Command的Cancel,只要調(diào)用DataReader的Close即可。

  二進(jìn)制大對(duì)象(BLOB)

  用DataReader檢索二進(jìn)制大對(duì)象(BLOB)時(shí),應(yīng)該將CommandBehavior.SequentialAccess傳遞給ExecuteReader方法調(diào)用。因?yàn)镈ataReader的默認(rèn)行為是每次Read都將整行加載到內(nèi)存,又因?yàn)锽LOB值可能非常大,所以結(jié)果可能由于單個(gè)BLOB而使大量?jī)?nèi)存被用光。SequentialAccess將DataReader的行為設(shè)置為只加載請(qǐng)求的數(shù)據(jù)。然后還可以使用GetBytes或GetChars控制每次加載多少數(shù)據(jù)。

  記住,使用SequentialAccess時(shí),不能不按順序訪問(wèn)DataReader返回的不同字段。也就是說(shuō),如果查詢返回三列,其中第三列是BLOB,并且想訪問(wèn)前兩列中的數(shù)據(jù),就必須在訪問(wèn)BLOB數(shù)據(jù)之前先訪問(wèn)第一列的值,然后訪問(wèn)第二列的值。這是因?yàn)楝F(xiàn)在數(shù)據(jù)是順序返回的,并且DataReader一旦讀過(guò)該數(shù)據(jù),該數(shù)據(jù)就不再可用。

  使用命令

  ADO.NET提供了幾種命令執(zhí)行的不同方法以及優(yōu)化命令執(zhí)行的不同選項(xiàng)。下面包括一些技巧,它們是關(guān)于選擇最佳命令執(zhí)行以及如何提高執(zhí)行命令的性能。

  使用OleDbCommand的最佳實(shí)踐

  不同.NET框架數(shù)據(jù)提供程序之間的命令執(zhí)行被盡可能標(biāo)準(zhǔn)化了。但是,數(shù)據(jù)提供程序之間仍然存在差異。下面給出一些技巧,可微調(diào)用于OLE DB的.NET框架數(shù)據(jù)提供程序的命令執(zhí)行。

  1) 按照ODBC CALL語(yǔ)法使用CommandType.Text調(diào)用存儲(chǔ)過(guò)程。使用CommandType.StoredProcedure只是秘密地生成ODBC CALL語(yǔ)法。
2) 一定要設(shè)置OleDbParameter的類型、大小(如果適用)、以及精度和范圍(如果參數(shù)類型是numeric或decimal)。注意,如果不顯式提供參數(shù)信息,OleDbCommand會(huì)為每個(gè)執(zhí)行命令重新創(chuàng)建OLE DB參數(shù)訪問(wèn)器。

  使用SqlCommand的最佳實(shí)踐

  使用SqlCommand執(zhí)行存儲(chǔ)過(guò)程的快速提示:如果調(diào)用存儲(chǔ)過(guò)程,將SqlCommand的CommandType屬性指定為StoredProcedure的CommandType。這樣通過(guò)將該命令顯式標(biāo)識(shí)為存儲(chǔ)過(guò)程,就不需要在執(zhí)行之前分析命令。

  使用Prepare方法

  對(duì)于重復(fù)作用于數(shù)據(jù)源的參數(shù)化命令,Command.Prepare方法能提高性能。Prepare指示數(shù)據(jù)源為多次調(diào)用優(yōu)化指定的命令。要想有效利用Prepare,需要徹底理解數(shù)據(jù)源是如何響應(yīng)Prepare調(diào)用的。對(duì)于一些數(shù)據(jù)源(例如SQL Server 2000),命令是隱式優(yōu)化的,不必調(diào)用Prepare。對(duì)于其他(例如SQL Server 7.0)數(shù)據(jù)源,Prepare會(huì)比較有效。

  顯式指定架構(gòu)和元數(shù)據(jù)

  只要用戶沒(méi)有指定元數(shù)據(jù)信息,ADO.NET的許多對(duì)象就會(huì)推斷元數(shù)據(jù)信息。下面是一些示例:

  1) DataAdapter.Fill方法,如果DataSet中沒(méi)有表和列,DataAdapter.Fill方法會(huì)在DataSet中創(chuàng)建表和列。

  2) CommandBuilder,它會(huì)為單表SELECT命令生成DataAdapter命令屬性。

  3) CommandBuilder.DeriveParameters,它會(huì)填充Command對(duì)象的Parameters集合。

  但是,每次用到這些特性,都會(huì)有性能損失。建議將這些特性主要用于設(shè)計(jì)時(shí)和即席應(yīng)用程序中。在可能的情況下,顯式指定架構(gòu)和元數(shù)據(jù)。其中包括在DataSet中定義表和列、定義DataAdapter的Command屬性、以及為Command定義Parameter信息
如果想返回像Count(*)、Sum(Price)或Avg(Quantity)的結(jié)果那樣的單值,可以使用Command.ExecuteScalar。ExecuteScalar返回第一行第一列的值,將結(jié)果集作為標(biāo)量值返回。因?yàn)閱为?dú)一步就能完成,所以ExecuteScalar不僅簡(jiǎn)化了代碼,還提高了性能;要是使用DataReader就需要兩步才能完成(即,ExecuteReader+取值)。

  使用不返回行的SQL語(yǔ)句時(shí),例如修改數(shù)據(jù)(例如INSERT、UPDATE或DELETE)或僅返回輸出參數(shù)或返回值,請(qǐng)使用ExecuteNonQuery。這避免了用于創(chuàng)建空DataReader的任何不必要處理。

  測(cè)試Null

  如果表(在數(shù)據(jù)庫(kù)中)中的列允許為空,就不能測(cè)試參數(shù)值是否“等于”空。相反,需要寫一個(gè)WHERE子句,測(cè)試列和參數(shù)是否都為空。下面的SQL語(yǔ)句返回一些行,它們的LastName列等于賦給@LastName參數(shù)的值,或者LastName列和@LastName參數(shù)都為空。

SELECT * FROM Customers
WHERE ((LastName = @LastName) OR (LastName IS NULL AND @LastName IS NULL))?

  將Null作為參數(shù)值傳遞

  對(duì)數(shù)據(jù)庫(kù)的命令中,當(dāng)將空值作為參數(shù)值發(fā)送時(shí),不能使用null(Visual Basic .NET中為Nothing)。而需要使用DBNull.Value。例如:

'Visual Basic
Dim param As SqlParameter = New SqlParameter("@Name", SqlDbType.NVarChar, 20)
param.Value = DBNull.Value

//C#
SqlParameter param = new SqlParameter("@Name", SqlDbType.NVarChar, 20);
param.Value = DBNull.Value;?

  執(zhí)行事務(wù)

  ADO.NET的事務(wù)模型已經(jīng)更改。在ADO中,當(dāng)調(diào)用StartTransaction時(shí),調(diào)用之后的任何更新操作都被視為是事務(wù)的一部分。但是,在ADO.NET中,當(dāng)調(diào)用Connection .BeginTransaction時(shí),會(huì)返回一個(gè)Transaction對(duì)象,需要將它與Command的Transaction屬性聯(lián)系起來(lái)。這種設(shè)計(jì)可以在一個(gè)單一連接上執(zhí)行多個(gè)根事務(wù)。如果未將Command.Transaction屬性設(shè)置為一個(gè)針對(duì)相關(guān)的Connection而啟動(dòng)的Transaction,那么Command就會(huì)失敗并引發(fā)異常。

  即將發(fā)布的.NET框架將使您可以在現(xiàn)有的分布式事務(wù)中手動(dòng)登記。這對(duì)于對(duì)象池方案來(lái)說(shuō)很理想;在該方案中,一個(gè)池對(duì)象打開一次連接,但是在多個(gè)獨(dú)立的事務(wù)中都涉及到該對(duì)象。.NET框架1.0發(fā)行版中這一功能并不可用。

  使用連接

  高性能應(yīng)用程序與使用中的數(shù)據(jù)源保持最短時(shí)間的連接,并且利用性能增強(qiáng)技術(shù),例如連接池。下面的主題提供一些技巧,有助于在使用ADO.NET連接到數(shù)據(jù)源時(shí)獲得更好的性能。

  連接池

  用于ODBC的SQL Server、OLE DB和.NET框架數(shù)據(jù)提供程序隱式緩沖連接。通過(guò)在連接字符串中指定不同的屬性值,可以控制連接池的行為。

  用DataAdapter優(yōu)化連接

  DataAdapter的Fill和Update方法在連接關(guān)閉的情況下自動(dòng)打開為相關(guān)命令屬性指定的連接。如果Fill或Update方法打開了連接,Fill或Update將在操作完成的時(shí)候關(guān)閉它。為了獲得最佳性能,僅在需要時(shí)將與數(shù)據(jù)庫(kù)的連接保持為打開。同時(shí),減少打開和關(guān)閉多操作連接的次數(shù)。

  如果只執(zhí)行單個(gè)的Fill或Update方法調(diào)用,建議允許Fill或Update方法隱式打開和關(guān)閉連接。如果對(duì)Fill和Update調(diào)用有很多,建議顯式打開連接,調(diào)用Fill和Update,然后顯式關(guān)閉連接。

  另外,當(dāng)執(zhí)行事務(wù)時(shí),顯式地在開始事務(wù)之前打開連接,并在提交之后關(guān)閉連接。例如:

'Visual Basic
Public Sub RunSqlTransaction(da As SqlDataAdapter, myConnection As SqlConnection, ds As DataSet)
myConnection.Open()
Dim myTrans As SqlTransaction = myConnection.BeginTransaction()
myCommand.Transaction = myTrans

Try
da.Update(ds)
myTrans.Commit()
Console.WriteLine("Update successful.")
Catch e As Exception
Try
myTrans.Rollback()
Catch ex As SqlException
If Not myTrans.Connection Is Nothing Then
Console.WriteLine("An exception of type " & ex.GetType().ToString() & " was encountered while attempting to roll back the transaction.")
End If
End Try

Console.WriteLine("An exception of type " & e.GetType().ToString() & " was encountered.")
Console.WriteLine("Update failed.")
End Try
myConnection.Close()
End Sub

//C#
public void RunSqlTransaction(SqlDataAdapter da, SqlConnection myConnection, DataSet ds)
{
myConnection.Open();
SqlTransaction myTrans = myConnection.BeginTransaction();
myCommand.Transaction = myTrans;

try
{
da.Update(ds);
myCommand.Transaction.Commit();
Console.WriteLine("Update successful.");
}
catch(Exception e)
{
try
{
myTrans.Rollback();
}
catch (SqlException ex)
{
if (myTrans.Connection != null)
{
Console.WriteLine("An exception of type " + ex.GetType() +" was encountered while attempting to roll back the transaction.");
}
}

Console.WriteLine(e.ToString());
Console.WriteLine("Update failed.");
}
myConnection.Close();
}

  始終關(guān)閉Connection和DataReader
? [轉(zhuǎn)自:51item.net]?
  完成對(duì)Connection或DataReader對(duì)象的使用后,總是顯式地關(guān)閉它們。盡管垃圾回收最終會(huì)清除對(duì)象并因此釋放連接和其他托管資源,但垃圾回收僅在需要時(shí)執(zhí)行。因此,確保任何寶貴的資源被顯式釋放仍然是您的責(zé)任。并且,沒(méi)有顯式關(guān)閉的Connections可能不會(huì)返回到池中。例如,一個(gè)超出作用范圍卻沒(méi)有顯式關(guān)閉的連接,只有當(dāng)連接池大小達(dá)到最大并且連接仍然有效時(shí),才會(huì)被返回到連接池中。

  注不要在類的Finalize方法中對(duì)Connection、DataReader或任何其他托管對(duì)象調(diào)用Close或Dispose。最后完成的時(shí)候,僅釋放類自己直接擁有的非托管資源。如果類沒(méi)有任何非托管資源,就不要在類定義中包含F(xiàn)inalize方法。
對(duì)于C#程序員來(lái)說(shuō),確保始終關(guān)閉Connection和DataReader對(duì)象的一個(gè)方便的方法就是使用using語(yǔ)句。using語(yǔ)句在離開自己的作用范圍時(shí),會(huì)自動(dòng)調(diào)用被“使用”的對(duì)象的Dispose。例如:

//C#
string connString = "Data Source=localhost;Integrated Security=SSPI;Initial Catalog=Northwind;";

using (SqlConnection conn = new SqlConnection(connString))
{
SqlCommand cmd = conn.CreateCommand();
cmd.CommandText = "SELECT CustomerId, CompanyName FROM Customers";

conn.Open();

using (SqlDataReader dr = cmd.ExecuteReader())
{
while (dr.Read())
Console.WriteLine("{0}\t{1}", dr.GetString(0), dr.GetString(1));
}
}

  Using語(yǔ)句不能用于Microsoft Visual Basic .NET。
 
  避免訪問(wèn)OleDbConnection.State屬性

  如果連接已經(jīng)打開,OleDbConnection.State屬性會(huì)對(duì)DBPROP_CONNECTIONSTATUS屬性的DATASOURCEINFO屬性集執(zhí)行本地OLE DB調(diào)用IDBProperties.GetProperties,這可能會(huì)導(dǎo)致對(duì)數(shù)據(jù)源的往返行程。也就是說(shuō),檢查State屬性的代價(jià)可能很高。所以僅在需要時(shí)檢查State屬性。如果需要經(jīng)常檢查該屬性,監(jiān)聽OleDbConnection的StateChange事件可能會(huì)使應(yīng)用程序的性能好一些。

  與XML集成

  ADO.NET在DataSet中提供了廣泛的XML集成,并公開了SQL Server 2000及其更高版本提供的部分XML功能。還可以使用SQLXML 3.0廣泛地訪問(wèn)SQL Server 2000及其更高版本中的XML功能。下面是使用XML和ADO.NET的技巧和信息。

  DataSet和XML

  DataSet與XML緊密集成,并提供如下功能:

  1) 從XSD架構(gòu)中加載DataSet的架構(gòu)或關(guān)系型結(jié)構(gòu)。

  2) 從XML加載DataSet的內(nèi)容。

  3) 如果沒(méi)有提供架構(gòu),可以從XML文檔的內(nèi)容推斷出DataSet的架構(gòu)。

  4) 將DataSet的架構(gòu)寫為XSD架構(gòu)。

  5) 將DataSet的內(nèi)容寫為XML。

  6) 同步訪問(wèn)使用DataSet的數(shù)據(jù)的關(guān)系表示,以及使用XmlDataDocument的數(shù)據(jù)的層次表示。

  注可以使用這種同步將XML功能(例如,XPath查詢和XSLT轉(zhuǎn)換)應(yīng)用到DataSet中的數(shù)據(jù),或者在保留原始XML保真度的前提下為XML文檔中數(shù)據(jù)的全部或其中一個(gè)子集提供關(guān)系視圖。

  架構(gòu)推斷

  從XML文件加載DataSet時(shí),可以從XSD架構(gòu)加載DataSet架構(gòu),或者在加載數(shù)據(jù)前預(yù)定義表和列。如果沒(méi)有可用的XSD架構(gòu),而且不知道為XML文件的內(nèi)容定義哪些表和列,就可以在XML文檔結(jié)構(gòu)的基礎(chǔ)上對(duì)架構(gòu)進(jìn)行推斷。

  架構(gòu)推斷作為遷移工具很有用,但應(yīng)只限于設(shè)計(jì)階段應(yīng)用程序,這是由于推斷處理有如下限制。

  1) 對(duì)架構(gòu)的推斷會(huì)引入影響應(yīng)用程序性能的附加處理。

  2) 所有推斷列的類型都是字符串。

  3) 推斷處理不具有確定性。也就是說(shuō),它是基于XML文件內(nèi)容的,而不是預(yù)定的架構(gòu)。因此,對(duì)于兩個(gè)預(yù)定架構(gòu)相同的XML文件,由于它們的內(nèi)容不同,結(jié)果得到兩個(gè)完全不同的推斷架構(gòu)。

  用于XML查詢的SQL Server

  如果正從SQL Server 2000 FOR XML返回查詢結(jié)果,可以讓用于SQL Server的.NET框架數(shù)據(jù)提供程序使用SqlCommand.ExecuteXmlReader方法直接創(chuàng)建一個(gè)XmlReader。

  SQLXML托管類

  .NET框架中有一些類,公開用于SQL Server 2000的XML的功能。這些類可在Microsoft.Data.SqlXml命名空間中找到,它們添加了執(zhí)行XPath查詢和XML模板文件以及將XSLT轉(zhuǎn)換應(yīng)用到數(shù)據(jù)的能力。

  SQLXML托管類包含在用于Microsoft SQL Server 2000的XML (SQLXML 2.0)發(fā)行版中,可通過(guò)鏈接XML for Microsoft SQL Server 2000 Web Release 2 (SQLXML 2.0)

  更多有用的技巧

  下面是一些編寫ADO.NET代碼時(shí)的通用技巧。

  避免自動(dòng)增量值沖突

  就像大多數(shù)數(shù)據(jù)源一樣,DataSet使您可標(biāo)識(shí)那些添加新行時(shí)自動(dòng)對(duì)其值進(jìn)行遞增的列。在DataSet中使用自動(dòng)增量的列時(shí),如果自動(dòng)增量的列來(lái)自數(shù)據(jù)源,可避免添加到DataSet的行和添加到數(shù)據(jù)源的行之間本地編號(hào)沖突。

  例如,考慮一個(gè)表,它的主鍵列CustomerID是自動(dòng)增量的。兩個(gè)新的客戶信息行添加到表中,并接收到自動(dòng)增量的CustomerID值1和2。然后,只有第二個(gè)客戶行被傳遞給DataAdapter的方法Update,新添加的行在數(shù)據(jù)源接收到一個(gè)自動(dòng)增量的CustomerID值1,與DataSet中的值2不匹配。當(dāng)DataAdapter用返回值填充表中第二行時(shí),就會(huì)出現(xiàn)約束沖突,因?yàn)榈谝粋€(gè)客戶行已經(jīng)使用了CustomerID值1。

  要避免這種情況,建議在使用數(shù)據(jù)源上自動(dòng)增量的列以及DataSet上自動(dòng)增量的列時(shí),將DataSet中的列創(chuàng)建為AutoIncrementStep值等于-1并且AutoIncrementSeed值等于0,另外,還要確保數(shù)據(jù)源生成的自動(dòng)增量標(biāo)識(shí)值從1開始,并且以正階值遞增。因此,DataSet為自動(dòng)增量值生成負(fù)數(shù),與數(shù)據(jù)源生成的正自動(dòng)增量值不沖突。另外一個(gè)選擇是使用GUID類型的列,而不是自動(dòng)增量的列。生成GUID值的算法應(yīng)該永遠(yuǎn)不會(huì)使數(shù)據(jù)源中生成的GUID值與DataSet中生成的GUID值一樣。

  如果自動(dòng)增量的列只是用作唯一值,而且沒(méi)有任何意義,就考慮使用GUID代替自動(dòng)增量的列。它們是唯一的,并且避免了使用自動(dòng)增量的列所必需的額外工作。

  檢查開放式并發(fā)沖突

  按照設(shè)計(jì),由于DataSet是與數(shù)據(jù)源斷開的,所以,當(dāng)多個(gè)客戶端在數(shù)據(jù)源上按照開放式并發(fā)模型更新數(shù)據(jù)時(shí),需要確保應(yīng)用程序避免沖突。

  在測(cè)試開放式并發(fā)沖突時(shí)有幾項(xiàng)技術(shù)。一項(xiàng)技術(shù)涉及在表中包含時(shí)間戳列。另外一項(xiàng)技術(shù)是,驗(yàn)證一行中所有列的原始值是否仍然與通過(guò)在SQL語(yǔ)句中使用WHERE子句進(jìn)行測(cè)試時(shí)在數(shù)據(jù)庫(kù)中找到的值相匹配。

  多線程編程

  ADO.NET對(duì)性能、吞吐量和可伸縮性進(jìn)行優(yōu)化。因此,ADO.NET對(duì)象不鎖定資源,并且必須只用于單線程。一個(gè)例外是DataSet,它對(duì)多個(gè)閱讀器是線程安全的。但是,在寫的時(shí)候需要將DataSet鎖定。

  僅在需要的時(shí)候才用COM Interop訪問(wèn)ADO

  ADO.NET的設(shè)計(jì)目的是成為許多應(yīng)用程序的最佳解決方案。但是,有些應(yīng)用程序需要只有使用ADO對(duì)象才有的功能,例如,ADO多維(ADOMD)。在這些情況下,應(yīng)用程序可以用COM Interop訪問(wèn)ADO。注意使用COM Interop訪問(wèn)具有ADO的數(shù)據(jù)會(huì)導(dǎo)致性能降低。在設(shè)計(jì)應(yīng)用程序時(shí),首先在實(shí)現(xiàn)用COM Interop訪問(wèn)ADO的設(shè)計(jì)之前,先確定ADO.NET是否滿足設(shè)計(jì)需求。

與50位技術(shù)專家面對(duì)面20年技術(shù)見證,附贈(zèng)技術(shù)全景圖

總結(jié)

以上是生活随笔為你收集整理的ADO.NET实用经验 转载的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

精品久久久久久久久久岛国gif | 中文字幕麻豆 | 日韩久久久久久久 | 中文字幕久久精品亚洲乱码 | 国产高清在线免费观看 | 97超碰人人模人人人爽人人爱 | 久久99最新地址 | 米奇狠狠狠888 | 99色在线| 在线天堂亚洲 | 中文字幕电影高清在线观看 | 免费看片色 | bbb搡bbb爽爽爽 | 久草在线视频免赞 | 久久午夜电影网 | 日韩在线视频一区二区三区 | 天无日天天操天天干 | 久久久久久久久久久久久久av | 国产精品美女久久久久久久久 | 99精品久久久久久久久久综合 | 久久久18| av在线免费播放 | 狠狠色伊人亚洲综合网站色 | 久久人网 | 亚洲国产精品小视频 | 亚洲一片黄 | 成人免费网视频 | 色资源网免费观看视频 | 国产97碰免费视频 | 亚洲精品高清视频 | 深夜国产在线 | 91麻豆免费看 | 热久久免费国产视频 | 免费日韩视| 99热国内精品 | 色综合综合| 天天操天天艹 | 人人干97 | 欧美日韩在线免费观看 | 亚洲成人动漫在线观看 | 国产九色视频在线观看 | 波多野结衣网址 | 欧美日韩不卡在线视频 | 精品国产一区二区三区久久久久久 | 看片在线亚洲 | 在线视频 影院 | 天天草视频 | 欧美久久成人 | 久久免费看av | 精品一二三区视频 | 精品自拍网| 三级视频日韩 | 久久精品人人做人人综合老师 | 伊人色综合久久天天网 | 日本黄区免费视频观看 | 天天草天天色 | 中文字幕在线观看一区二区 | 人人干人人搞 | 天堂av中文字幕 | 久久免费中文视频 | av在线之家电影网站 | 成人黄色在线 | 国产99久久久国产精品免费二区 | 国产亲近乱来精品 | 亚洲免费视频观看 | www在线观看视频 | 福利一区二区三区四区 | 蜜臀av性久久久久av蜜臀妖精 | 一本一道久久a久久综合蜜桃 | 五月婷婷在线视频观看 | 四虎最新域名 | 麻豆视频在线 | 久久激情婷婷 | 尤物一区二区三区 | 日本精品视频在线播放 | 99久久久久久久久久 | 香蕉视频在线网站 | 免费在线观看黄色网 | 一本到视频在线观看 | 午夜91视频 | 久久久亚洲麻豆日韩精品一区三区 | 欧美精品第一 | 丁香视频五月 | 成年人网站免费在线观看 | 国产精品成人国产乱 | av免费在线播放 | 国产精品成人一区二区三区吃奶 | 手机在线欧美 | 最近免费观看的电影完整版 | 在线免费日韩 | 日本精品视频在线观看 | 欧美精品乱码久久久久久 | 国产综合小视频 | 中文字幕精品三级久久久 | 精品视频久久久久久 | 伊人夜夜 | 麻豆精品视频在线 | 日韩v在线91成人自拍 | 视频国产一区二区三区 | 五月婷婷六月丁香 | 久久精品一区二区三区视频 | 久香蕉 | 狠狠色丁香婷综合久久 | 欧美福利片在线观看 | 日韩中文在线字幕 | 国产小视频在线观看免费 | 久久久久欠精品国产毛片国产毛生 | 激情视频亚洲 | 99999精品视频 | 久久少妇| 不卡在线一区 | 99久久婷婷国产一区二区三区 | 日韩69视频 | 成人在线播放免费观看 | 色97在线 | 在线观看亚洲精品 | 国产99色 | 91av免费在线观看 | 亚洲一区日韩 | 国产精品乱码久久久久久1区2区 | 在线精品视频免费播放 | wwxxx日本| 亚洲精品国产精品国自 | 特级a毛片| 日韩精品不卡在线 | 国产黄色片在线免费观看 | 国产麻豆电影在线观看 | 狠狠狠色丁香综合久久天下网 | 日韩精品一区二区三区视频播放 | 最新成人在线 | 四虎天堂| 日韩高清dvd| 免费三级在线 | 少妇资源站 | 亚洲成人家庭影院 | 久久精品视频中文字幕 | 久久久久久久99精品免费观看 | 欧美日韩大片在线观看 | 亚洲最新av | 五月婷婷毛片 | 色小说在线 | 日韩毛片在线一区二区毛片 | 婷婷爱五月天 | 九七人人干 | 欧美男男激情videos | 一区 二区电影免费在线观看 | 一本—道久久a久久精品蜜桃 | 久久久久久高潮国产精品视 | 高清一区二区 | 亚洲成aⅴ人在线观看 | 国产精品久久久久久久婷婷 | 欧美精品日韩 | 香蕉网在线观看 | 国产一区精品在线 | 99超碰在线观看 | www.婷婷com| 久久免费99 | 中文字幕永久 | 久久色亚洲 | 不卡的av在线播放 | 色偷偷网站视频 | 欧美日韩视频在线播放 | 亚洲最大av| 国产一级做a | 久久夜夜爽 | av亚洲产国偷v产偷v自拍小说 | 久久免费影院 | 久久精品久久久久久久 | 色五丁香| 午夜精品福利影院 | 九九在线精品视频 | 贫乳av女优大全 | 中文区中文字幕免费看 | 久久国产免费视频 | 国产精品久久久久久一区二区三区 | 亚洲欧美日本国产 | 久久综合婷婷国产二区高清 | 亚洲精品国产第一综合99久久 | 亚洲精品88欧美一区二区 | 国产精品久久久久久久久久三级 | 四虎亚洲精品 | 色狠狠久久av五月综合 | 国产精品日韩在线观看 | 99免费国产 | 国产无遮挡又黄又爽在线观看 | 亚洲女同videos| 天天久久综合 | 久久av网 | 国产日韩高清在线 | 国产玖玖在线 | 天天操天天色天天射 | 亚洲成人动漫在线观看 | 美女久久 | 日韩欧美视频一区 | 久久久久久伊人 | 国产精品午夜免费福利视频 | www国产亚洲精品久久麻豆 | 久久97久久 | 日韩欧美高清视频在线观看 | 亚洲精品久久久久www | 国产黄在线 | 国产午夜精品一区 | 日韩色区 | 在线精品亚洲一区二区 | 91亚色视频在线观看 | 在线观看色网 | 中文字幕视频一区二区 | 免费观看福利视频 | 99久久这里有精品 | 91porny九色91啦中文 | 国产日产在线观看 | 久久精品视频在线免费观看 | 毛片网站免费在线观看 | 丁香六月久久综合狠狠色 | 色婷婷www | 国产欧美精品在线观看 | 国产手机在线观看 | 黄色大全免费观看 | 亚洲 欧美日韩 国产 中文 | 欧美精品资源 | 免费在线一区二区 | 五月天久久精品 | 欧美久久电影 | 精品极品在线 | 国产精品毛片一区二区 | 国内精品久久久久影院男同志 | 成年人免费观看国产 | 九九热免费精品视频 | 久久一区国产 | 精品美女在线观看 | 久久99精品久久久久婷婷 | 亚洲精品黄网站 | 东方av在线免费观看 | av国产网站 | 日韩欧美在线观看一区二区三区 | 成人污视频在线观看 | 日日操天天射 | 亚洲综合激情五月 | 日韩网站免费观看 | 日本精品中文字幕在线观看 | 国产精品成人一区二区 | 中文字幕高清在线 | 亚洲黄色免费在线 | 日韩理论在线观看 | 国产成人免费 | 久久九九国产视频 | 欧美日韩高清一区 | 国产最新在线视频 | 黄色大片av | 久久综合桃花 | 久久最新网址 | 97超碰国产精品 | 伊人五月天婷婷 | 激情综合色综合久久 | 91精品老司机久久一区啪 | 五月婷婷香蕉 | 日本久久精品视频 | 天天天色| 丁香激情网| 在线国产黄色 | 久久视频在线观看 | 日韩免费电影网站 | 亚洲一级黄色大片 | 网站在线观看你们懂的 | 亚洲一级片 | 五月婷婷av在线 | 五月婷婷综合激情网 | 国产玖玖精品视频 | 婷婷国产在线观看 | 日韩欧美在线观看一区二区三区 | 精品国产不卡 | 国产五十路毛片 | 免费一级片在线 | 九九久久视频 | 国产精品乱码久久久 | 菠萝菠萝蜜在线播放 | 高清av免费观看 | 在线播放一区二区三区 | 91av福利视频 | 免费v片 | 麻豆久久久久久久 | 国产第一页在线播放 | 日韩精品一二三 | 亚洲成色| 天天艹天天干天天 | 天天色成人 | 亚洲天堂网在线视频 | 安徽妇搡bbbb搡bbbb | 国产在线观看污片 | 中文字幕国产视频 | 超碰在线观看97 | 在线免费观看视频a | 激情综合网五月 | 中文区中文字幕免费看 | 在线看成人av | 一区二区精品在线观看 | 亚洲精色 | 91视频亚洲 | 不卡av电影在线观看 | 国产精品夜夜夜一区二区三区尤 | 国产免费成人av | 27xxoo无遮挡动态视频 | 玖草在线观看 | 国产香蕉久久精品综合网 | 香蕉视频色 | 国产伦精品一区二区三区在线 | 91人人射| 日韩欧美高清在线 | 丁香5月婷婷 | 麻豆免费在线播放 | 国产手机精品视频 | 国产精品久久久久久久久久久免费 | 毛片一区二区 | 中文字幕电影高清在线观看 | 久操伊人 | 91完整视频 | 久久精品中文字幕 | 人人爽人人爽人人片 | 久久人人精 | 亚洲视频在线观看 | 久久在线观看 | 国产精品男女 | 91大神精品视频 | 免费看毛片在线 | 91久久国产综合精品女同国语 | 天天操天 | 久久久国产精品人人片99精片欧美一 | 欧美91成人网 | 久久精品国产免费看久久精品 | 免费视频久久久 | 久久久黄视频 | 97av在线视频 | 国产高清永久免费 | 国产99一区二区 | 国产成人一区二 | 青青草久草在线 | 久久精品79国产精品 | 亚洲国产高清视频 | 中文字幕在线观看日本 | 在线亚洲成人 | 精品二区视频 | 久久成人综合 | 日日夜夜精品网站 | 丁香午夜婷婷 | 激情伊人五月天久久综合 | 国产精品久久久影视 | 99c视频在线 | 天天干夜夜夜操天 | а天堂中文最新一区二区三区 | 久久精品亚洲精品国产欧美 | 黄色毛片网站在线观看 | 国内精品久久久久久久久久清纯 | 国产在线第三页 | 欧美日本国产在线观看 | 在线观看视频一区二区三区 | 伊人导航 | 亚洲自拍偷拍色图 | 免费看十八岁美女 | 超碰97在线看 | 久久精品国亚洲 | 日韩在线看片 | 欧美午夜视频在线 | 91最新在线视频 | 欧美精品久久久久a | 午夜美女福利直播 | 四虎在线视频 | 久久不色| 精品中文字幕视频 | 国产破处在线视频 | 亚洲精品福利在线观看 | 久久久亚洲麻豆日韩精品一区三区 | 人人爽人人爽人人片 | 亚洲一二三久久 | 在线观看视频国产 | 亚洲黄色av网址 | 国产中文字幕一区 | 人人躁 | 国产精品久久久久久久久免费 | 精产嫩模国品一二三区 | 成人黄色大片在线观看 | av电影亚洲 | 日本精品一区二区三区在线播放视频 | 久久免费电影网 | 91人人在线 | 国产精品免费在线观看视频 | 日日干天夜夜 | 亚洲色图22p | 亚洲精品91天天久久人人 | 久久情爱 | 久草在线视频看看 | 夜夜爱av | 久久伦理影院 | 午夜精品久久久久久久99无限制 | 久久精品人人做人人综合老师 | 中文av日韩 | 人人艹人人 | 亚洲精品中文在线资源 | 在线观看免费高清视频大全追剧 | 九九免费在线观看视频 | 香蕉视频免费看 | 中文视频在线 | 国产特黄色片 | 免费av小说| www麻豆视频 | 99这里有精品 | 99精品一区 | 在线中文字幕播放 | 免费观看视频黄 | 日本女人逼 | 天天做天天干 | 91资源在线视频 | 亚洲乱亚洲乱亚洲 | 九九视频在线播放 | 精品毛片一区二区免费看 | 日韩在线观看一区 | 天天色天天操综合 | 日韩在线观看视频一区二区三区 | 国产精品免费久久久久久 | 婷婷激情五月 | 国产精品欧美日韩 | 99热在线观看免费 | 亚洲欧美国产精品久久久久 | 激情五月婷婷 | 久久九九免费视频 | 国产免费视频在线 | 国产 日韩 欧美 中文 在线播放 | 欧美一级裸体视频 | 丁香五月缴情综合网 | 青青河边草免费观看完整版高清 | 欧美精品久久久久久久久久白贞 | 免费看色视频 | 福利精品在线 | 国产精品毛片久久久久久 | 日韩精品中文字幕在线播放 | 美女在线免费观看视频 | 精品久久久久久亚洲综合网站 | 国产九九精品视频 | 免费日韩av片 | 深爱激情开心 | 日韩视频免费播放 | 成人羞羞免费 | 中文字幕永久免费 | 色综合天天综合网国产成人网 | 日日夜夜中文字幕 | 狠狠干美女 | 在线免费av观看 | 国内精品久久久久影院男同志 | 国产视频一区二区在线播放 | 天天弄天天干 | 久久99热久久99精品 | 一区二区三区免费播放 | 免费网址在线播放 | 丰满少妇在线观看网站 | 成年在线观看 | 草在线 | 8x成人免费视频 | 亚洲japanese制服美女 | 四虎成人精品在永久免费 | 中文字幕 影院 | 天天操天| 国产福利精品一区二区 | 国产高清在线免费观看 | 久草在线最新免费 | 精品久久一区二区三区 | 国产成人精品一区二区三区免费 | 久久爱导航 | 久草免费色站 | 亚洲欧美色婷婷 | 欧美91精品 | av爱干 | 国产人成看黄久久久久久久久 | 欧美激情综合色 | 四虎视频 | 久久91网 | 久久看免费视频 | av网站播放 | 免费黄a| 在线观看黄色大片 | 探花视频免费观看高清视频 | 久久99热这里只有精品 | 国语麻豆 | 一区二区三区精品在线视频 | 久久无码精品一区二区三区 | 九九色在线观看 | 一区在线观看 | 免费男女羞羞的视频网站中文字幕 | 欧美一级片在线播放 | 日韩色一区二区三区 | 成人毛片一区 | 美女国内精品自产拍在线播放 | 久久免费视频在线 | 97操碰| 女人高潮一级片 | 91免费观看视频网站 | 午夜三级在线 | 国产999视频在线观看 | 亚洲第一av在线 | 免费在线观看日韩视频 | 99久久精品国产一区二区三区 | 亚洲精品国产综合久久 | 国产精品av在线免费观看 | 精品国产一区二区三区四 | h视频在线看 | 日本成人黄色片 | 欧美精品久久久久久久免费 | 99视频在线观看免费 | 91九色在线| 少妇自拍av | 又色又爽的网站 | 国产色秀视频 | 色婷婷免费 | 欧美福利精品 | avsex| 性色av一区二区三区在线观看 | 国产乱对白刺激视频不卡 | 成年人免费av网站 | 天堂在线免费视频 | 在线亚洲人成电影网站色www | 国产精品门事件 | 在线观看91久久久久久 | 欧美最猛性xxxx | 97综合视频 | 成人在线视频论坛 | 成年人免费看 | 免费男女羞羞的视频网站中文字幕 | 国产视频一区二区在线观看 | 顶级bbw搡bbbb搡bbbb | 在线有码中文 | 日本资源中文字幕在线 | 成人激情开心网 | 五月婷丁香 | 97成人超碰 | 国产视频 亚洲精品 | 欧美日韩久久不卡 | av7777777| 香蕉91视频 | av7777777| 天天鲁天天干天天射 | 五月婷婷中文字幕 | 国产精品18久久久久久久网站 | 韩国精品福利一区二区三区 | 狠狠亚洲| 国产成人在线精品 | 日韩免费高清在线 | 涩涩资源网 | 亚洲三级精品 | 久草在线免费电影 | www.色综合.com | 国产精品欧美日韩在线观看 | 精品国产视频在线 | 美国av大片 | 精品在线一区二区三区 | 久久久久麻豆 | 久久久久久久久亚洲精品 | 999精品网 | 欧美一二三视频 | 色综合久久中文综合久久牛 | 成年人在线播放视频 | 亚洲精品乱码久久久久久高潮 | 国产美女免费观看 | 91精品久久久久久综合乱菊 | 91精品国产91热久久久做人人 | 在线免费看片 | 天堂网一区二区 | 午夜视频免费在线观看 | 久久久亚洲麻豆日韩精品一区三区 | 欧美二区三区91 | 在线观看va | 美女国产在线 | 最近中文字幕国语免费av | av中文字幕免费在线观看 | 天天综合天天做 | 亚洲精品成人av在线 | a黄色| 4438全国亚洲精品观看视频 | 亚洲精品网址在线观看 | 欧美精品一区在线发布 | 干干夜夜 | 亚洲免费av在线播放 | 久久成人在线视频 | 欧美性大战 | 免费成人在线观看 | 国产黄色精品在线观看 | 国产精彩视频一区二区 | 欧美日韩在线观看一区二区三区 | 天天射综合网视频 | av中文字幕在线免费观看 | 久久久精品国产一区二区电影四季 | 91麻豆精品国产91 | 久久天堂精品视频 | 超碰人人在线 | www.久久久.com| 国产黄色成人av | 波多野结衣一区 | 夜夜爽www| 在线播放第一页 | 91成人精品国产刺激国语对白 | 精品主播网红福利资源观看 | 亚洲精品自拍视频在线观看 | 国产在线播放一区二区 | 国产一级黄色电影 | 国产精品久久久久久久久久 | 日韩中文字幕免费 | www.五月天色| 99产精品成人啪免费网站 | 国产一区二区高清不卡 | 黄av免费在线观看 | 久久精品96| 欧美日韩中文国产 | 人成午夜视频 | 天天操天天射天天操 | 久久婷婷久久 | 日韩免费一区 | 免费视频91蜜桃 | 国产亚洲在 | 久av在线 | 黄色成人av网址 | 国产第一页福利影院 | 一级黄色片在线 | 在线观看你懂的网址 | 亚洲一区二区三区四区在线视频 | 日韩在线二区 | 国产亚洲字幕 | 91九色国产在线 | 少妇搡bbbb搡bbb搡69 | 午夜美女av | 视频一区在线播放 | 国产欧美在线一区二区三区 | 亚洲日本激情 | 97碰视频| 精品福利在线观看 | 夜色成人网 | 亚洲高清在线观看视频 | 国产在线成人 | 欧美性做爰猛烈叫床潮 | 在线午夜av | 日日摸日日添日日躁av | 日日干天天操 | 亚洲三级av| 亚洲高清资源 | 亚洲精品一区二区三区高潮 | 美女福利视频 | 欧美激情视频在线免费观看 | 黄色特级毛片 | 中文字幕色播 | 国产明星视频三级a三级点| 九九九九热精品免费视频点播观看 | 日韩中文字幕一区 | 99爱国产精品 | av片在线观看 | 干天天| 日韩精品久久久久 | 久久视频二区 | 91九色精品女同系列 | 久热电影 | 四虎国产精品成人免费影视 | 国产精品国产三级国产aⅴ无密码 | 日韩精品一区在线观看 | 亚洲免费国产 | 国产视频在线免费 | 日韩视频一区二区在线观看 | 国产视频一二三 | 国产综合视频在线观看 | 免费色av | 亚洲天堂网在线视频观看 | 国产精品字幕 | 香蕉视频日本 | 国产在线精品二区 | 91久久国产综合精品女同国语 | 丁香六月婷婷 | 久久久久久久久综合 | 黄色福利网站 | 国产精品免费在线观看视频 | 中文字幕在线观看免费 | 亚洲影院色 | 色婷婷av国产精品 | 日韩r级电影在线观看 | 97电影在线观看 | 亚洲成人av在线电影 | 中文字幕在线高清 | 在线视频99 | 亚洲国产人午在线一二区 | 久久久久免费 | 九色视频网 | av大片免费| 国产综合福利在线 | 精品亚洲二区 | 欧美一区二区精品在线 | 久久成 | 婷婷五月在线视频 | 久久人人添人人爽添人人88v | 国产成人精品亚洲精品 | 国产精品不卡在线播放 | 免费在线中文字幕 | 国产综合福利在线 | ,午夜性刺激免费看视频 | 一区二区三区国产精品 | 日韩高清不卡一区二区三区 | 99久久电影 | 免费看黄在线网站 | 欧美日韩视频在线播放 | 成人午夜免费剧场 | 国内精品免费 | 亚洲国产婷婷 | 色综合久久综合中文综合网 | 成人黄色资源 | 一区二精品 | 欧美一级片在线观看视频 | 国产精品久久二区 | 国产精品99久久久久人中文网介绍 | 色婷婷骚婷婷 | 五月婷婷视频在线 | 国产97碰免费视频 | 国产一区二区在线看 | 日韩精品一区在线播放 | 日本中文字幕观看 | 亚洲国产一区在线观看 | 免费黄色小网站 | 91av色| 日韩在线激情 | 婷婷久久五月天 | 久草线| 色综合久久88 | 免费美女av | 久久兔费看a级 | 91九色视频观看 | 99久久精品免费看国产 | 日日夜夜免费精品视频 | 999久久久久久久久6666 | 欧美在线视频第一页 | 久草.com| 中文字幕日本在线 | 久久免费高清视频 | 国产a国产a国产a | 色婷婷成人网 | 99在线观看免费视频精品观看 | 成人h电影| 在线观看亚洲国产 | 国产精品美女久久久久久免费 | 久热电影| 最近中文字幕完整视频高清1 | 狠狠网| 91男人影院 | 国产黄视频在线观看 | 特级西西444www高清大视频 | 婷婷成人在线 | 亚州黄色一级 | 欧美先锋影音 | 日韩av高清 | 91麻豆看国产在线紧急地址 | 欧美网址在线观看 | av线上看| 成人一级黄色片 | 日韩在线网址 | 在线视频精品 | 人交video另类hd | 欧美精品在线一区二区 | 亚洲一区二区三区毛片 | 男女激情免费网站 | 欧美另类交在线观看 | 中文字幕有码在线观看 | 五月花丁香婷婷 | 三级在线视频播放 | 久久久久欠精品国产毛片国产毛生 | 免费在线观看毛片网站 | 在线视频你懂得 | 中文字幕日本在线 | 亚洲美女在线一区 | 久久精品播放 | 日韩色一区二区三区 | 国产精品久久久久久久久软件 | 国产精品美乳一区二区免费 | 超级碰碰碰免费视频 | 亚洲精品久久久蜜桃直播 | 色婷婷在线观看视频 | 91av精品 | 亚洲在线视频免费 | 91精品无人成人www | 五月婷婷一区二区三区 | 国产成人免费av电影 | 免费福利小视频 | 天天干天天干天天干天天干天天干天天干 | 免费电影一区二区三区 | 国产日韩欧美在线观看视频 | 在线v | 久久免费成人精品视频 | 婷婷久月 | 曰本三级在线 | 91一区二区三区在线观看 | 国产传媒中文字幕 | 日韩精品视频在线观看免费 | 欧美影院久久 | 伊人伊成久久人综合网小说 | 91一区啪爱嗯打偷拍欧美 | 天天色成人网 | 九九热免费在线观看 | 久久久国产精品麻豆 | 丁香五月缴情综合网 | 久久精品国产一区 | 人人射 | 欧美日韩精品网站 | 亚洲免费观看在线视频 | 午夜精品福利影院 | 日本韩国精品在线 | 国产高清av在线播放 | 狠狠的日 | 黄色免费大片 | 国产一区二区在线播放视频 | 亚洲免费av网站 | 91视频最新网址 | 337p西西人体大胆瓣开下部 | 97香蕉久久超级碰碰高清版 | 性色av香蕉一区二区 | av先锋中文字幕 | 福利片视频区 | 亚洲国产精品va在线看黑人 | 人人爽人人舔 | 国产精品大片免费观看 | 久久久影视 | 亚洲精品五月天 | 日韩精品视频在线观看免费 | 中文字幕在线播放av | 亚洲精品国产精品国自产在线 | 91桃色免费视频 | 午夜影院三级 | 狠狠干中文字幕 | 日日夜夜免费精品 | 黄色电影在线免费观看 | 婷婷六月色 | 中文字幕在线观看完整版电影 | 国产高清视频免费最新在线 | 日韩影片在线观看 | 国产成人亚洲在线观看 | 久久99精品久久只有精品 | 女人18片毛片90分钟 | 操老逼免费视频 | 色视频成人在线观看免 | 免费av福利 | 99草视频 | 免费a视频 | 91视视频在线直接观看在线看网页在线看 | 国产精品入口66mio女同 | 麻豆精品视频在线 | jizz欧美性9 国产一区高清在线观看 | 久久6精品 | 欧美日韩国产区 | 在线成人av | 中文字幕一区二区三区四区视频 | 欧美日韩一区三区 | 69av视频在线 | 亚洲乱码精品久久久久 | 97在线视频免费看 | 国产成人精品久久二区二区 | 国产高清在线免费 | 日韩精品欧美专区 | 成人黄色大片在线免费观看 | 欧美激情精品 | 日本久久久影视 | 97超碰人人模人人人爽人人爱 | 狠狠狠狠干 | 韩国av免费看 | 欧美在线观看视频免费 | 99久久精品一区二区成人 | 欧美综合在线视频 | 色天天天 | 日韩午夜在线 | 亚洲精品国偷自产在线99热 | 久久久久久国产精品亚洲78 | 日韩欧美视频在线观看免费 | 天天拍天天草 | 日韩一区二区三区在线观看 | 国产高清在线免费视频 | 天堂av高清 | av一级久久 | 久久久久电影网站 | 日韩在线高清视频 | 精品视频在线播放 | 六月丁香伊人 | 99亚洲视频 | 伊人天堂av| 亚洲视频一 | 91视频在线国产 | 免费看一级特黄a大片 | 丁香激情五月 | 国产特级毛片aaaaaa高清 | 国产精品午夜久久久久久99热 | 天天艹天天 | 国产99久久久精品 | 蜜桃视频日韩 | 亚洲欧洲精品一区 | 五月综合婷 | 婷婷六月天天 | 国产最新视频在线观看 | 一级片免费观看视频 | 久久久精品免费观看 | 日本在线观看视频一区 | 久久a v视频 | 欧美伦理一区二区 | 欧美一区影院 | 99国产一区二区三精品乱码 | 黄色影院在线免费观看 | 中文字幕在线观看视频一区二区三区 | 欧美日韩亚洲精品在线 | 国产精品久久99综合免费观看尤物 | 亚洲 精品在线视频 | 99视频在线精品免费观看2 | 成av在线| 免费亚洲视频在线观看 | 在线观看av免费观看 | 中文资源在线播放 | 午夜视频在线瓜伦 | 福利一区二区三区四区 | 日日干天天爽 | 精品久久久久久国产91 | 精品久久久久久久久久久久久久久久久久 | 欧美综合干 | 久久国产热视频 | 国产精品麻豆果冻传媒在线播放 | 成人99免费视频 | 久久av一区二区三区亚洲 | 夜夜爱av| 国产免费又粗又猛又爽 | 超碰人人在 | 国产一级视频在线 | 人人超碰97| 亚洲在线资源 | 婷婷福利影院 | 亚洲一区 av | 黄色91在线| 欧美黑吊大战白妞欧美 | 国内精品视频在线 | 日本精品久久久久中文字幕5 | 午夜精品99久久免费 | 日韩亚洲在线 | 999久久久久久久久久久 | 免费看的毛片 | 婷婷视频| 国产麻豆精品久久一二三 | 久久久在线视频 | 99电影| 99久久er热在这里只有精品15 | 免费裸体视频网 | 国内久久精品视频 | 国产高清不卡 | 国产黄色精品在线 | 日韩在线视频线视频免费网站 | 日韩乱码在线 | 欧美日韩国产在线观看 | 亚洲伦理精品 | 午夜精品久久久久久久久久久 | 天天操夜夜摸 | 精品国产乱码久久久久久天美 | 在线观看免费版高清版 | 黄色福利网站 | av在观看 | 黄色av影院 | 99亚洲国产精品 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 九九热99视频| 久久伊人免费视频 | av片在线观看免费 | 天天躁日日躁狠狠 | 在线看的av网站 | 色噜噜色噜噜 | 黄网站污| 91在线播 | 日韩av高清在线观看 | 九色视频网址 | 亚洲精品久久久蜜桃直播 | 亚洲成人软件 | 国产99久久久国产精品免费二区 | 成人av av在线| 国产精品 中文在线 | 一区二区欧美在线观看 | 国产精品第二页 | www.com操| 97爱| 久久久久免费网站 | 91久久国产综合精品女同国语 | 国产精品久久一卡二卡 | 精品久久久久久久久久久院品网 | 日韩中文在线观看 | 97精品在线观看 | 狠狠操狠狠干天天操 | 99婷婷狠狠成为人免费视频 | 亚洲第一区在线播放 | 亚洲精品综合一二三区在线观看 | 综合久久网站 | 操操操人人 | 国产啊v在线 | 中文免费在线观看 | 粉嫩av一区二区三区四区在线观看 | 国产精品一区二区三区视频免费 | 精品国产三级 | 99久久婷婷国产综合亚洲 | 亚洲国产精彩中文乱码av | 综合色中色 | av在线一级 |