一起草最新网址_日韩一区二区麻豆国产_91视频婷婷_日本一区二区视频在线_日韩激情一区二区三区_国产另类第一区_成人免费在线播放视频_亚洲永久精品ww.7491进入_久久这里有精品视频_久久精品一级片_日韩av在线网页_波多野结衣不卡视频

ADO.NET實(shí)用經(jīng)驗(yàn)無保留曝光_.Net教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:asp.net/c#字符格式化
一、用{0:?}格式化 可通過 String.Format 方法或通過 Console.Write 方法格式化數(shù)值結(jié)果,其中后一種方法調(diào)用 String.Format 。使用格式字符串指定格式。下表包含受支持的標(biāo)準(zhǔn)格式字符串。格式字符串采用的形式為 Axx ,其中 A 為格式說明符,而 xx 為精度說

ADO.NET作為微軟最新的數(shù)據(jù)訪問技術(shù),已經(jīng)在企業(yè)開發(fā)中得到了廣泛的應(yīng)用。對(duì)于一線的開發(fā)人員來說,掌握基本的概念和技術(shù)之后,提高應(yīng)用水平和解決實(shí)際問題的最有效手段,莫過于相互交流彼此的最佳時(shí)間經(jīng)驗(yàn)經(jīng)驗(yàn)。在這篇文章中,兩位ADO.NET專家向讀者毫無保留地、詳盡地介紹了很多實(shí)用經(jīng)驗(yà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ì)目的就在于不通過任何附加技術(shù)層就可以直接訪問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è)來自數(shù)據(jù)庫的快速、僅向前、只讀數(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)化訪問它們所包含數(shù)據(jù)、以及如何優(yōu)化使用DataAdapter(包括CommandBuilder)和DataView的技巧。

DataSet與DataReader

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

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

1) 在結(jié)果的多個(gè)離散表之間進(jìn)行導(dǎo)航。

2) 操作來自多個(gè)數(shù)據(jù)源(例如,來自多個(gè)數(shù)據(jù)庫、一個(gè)XML文件和一個(gè)電子表格的混合數(shù)據(jù))的數(shù)據(jù)。

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

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

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

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

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

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

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

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

注填充DataSet時(shí),DataAdapter使用DataReader。因此,使用DataAdapter取代DataSet提升的性能表現(xiàn)為節(jié)省了DataSet占用內(nèi)存和填充DataSet需要的循環(huán)。一般來說,此性能提升只是象征性的,因此,設(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語句結(jié)束所帶來的好處。修改了DataSet的架構(gòu)或關(guān)系結(jié)構(gòu)后,就可以創(chuàng)建一個(gè)強(qiáng)類型DataSet,將行和列作為對(duì)象的屬性公開,而不是作為集合中的項(xiàng)公開。例如,不公開客戶表中行的姓名列,而公開Customer對(duì)象的Name屬性。類型化DataSet從DataSet類派生,因此不會(huì)犧牲DataSet的任何功能。也就是說,類型化DataSet仍能遠(yuǎn)程訪問,并作為數(shù)據(jù)綁定控件(例如DataGrid)的數(shù)據(jù)源提供。如果架構(gòu)事先不可知,仍能受益于通用DataSet的功能,但卻不能受益于強(qiáng)類型DataSet的附加功能。

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

使用強(qiáng)類型DataSet時(shí),可以使用DataSet的XML架構(gòu)定義語言(XSD)架構(gòu)來確保強(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。注意,如果沒有為DataTable定義主鍵,DataAdapter.Fill就用可能重復(fù)的主鍵值添加新行。

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

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)建兩次。

分頁

ADO.NET可以顯式控制從數(shù)據(jù)源中返回什么樣的數(shù)據(jù),以及在DataSet中本地緩存多少數(shù)據(jù)。對(duì)查詢結(jié)果的分頁沒有唯一的答案,但下面有一些設(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,但無論如何總是返回完整的查詢。這就會(huì)引起不必要的處理,用于讀取“不需要的”記錄;而且為了返回附加記錄,會(huì)耗盡不必要的服務(wù)器資源。

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

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

SELECT TOP 10 * FROM
(SELECT TOP 30 * FROM Customers ORDER BY Id ASC) AS Table1
ORDER BY Id DESC

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

1) 如果數(shù)據(jù)不經(jīng)常變動(dòng),可以在DataSet中本地維護(hù)一個(gè)記錄緩存,以此提高性能。例如,可以在本地DataSet中存儲(chǔ)10頁有用的數(shù)據(jù),并且只有當(dāng)用戶瀏覽超出緩存第一頁和最后一頁時(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中沒有表名與要被填充的表名相匹配,F(xiàn)ill方法就會(huì)創(chuàng)建一個(gè)表。默認(rèn)情況下,F(xiàn)ill僅定義列和列類型。

通過設(shè)置DataAdapter的MissingSchemaAction屬性,可以重寫Fill的默認(rèn)行為。例如,要讓Fill創(chuàng)建一個(gè)表架構(gòu),并且還包括主鍵信息、唯一約束、列屬性、是否允許為空、最大列長度、只讀列和自動(dòng)增量的列,就要將DataAdapter.MissingSchemaAction指定為MissingSchemaAction.AddWithKey。或者,在調(diào)用DataAdapter.Fill前,可以調(diào)用DataAdapter.FillSchema來確保當(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語句的內(nèi)容,就顯式設(shè)置它們。一個(gè)比較好的設(shè)計(jì)技巧是,為INSERT/UPDATE/DELETE命令創(chuàng)建存儲(chǔ)過程并顯式配置DataAdapter命令屬性以使用它們。

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

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

批處理SQL語句

很多數(shù)據(jù)庫支持將多條命令合并或批處理成一條單一命令執(zhí)行。例如,SQL Server使您可以用分號(hào)“;”分隔命令。將多條命令合并成單一命令,能減少到服務(wù)器的行程數(shù),并提高應(yīng)用程序的性能。例如,可以將所有預(yù)定的刪除在應(yīng)用程序中本地存儲(chǔ)起來,然后再發(fā)出一條批處理命令調(diào)用,從數(shù)據(jù)源刪除它們。

雖然這樣做確實(shí)能提高性能,但是,當(dāng)對(duì)DataSet中的數(shù)據(jù)更新進(jìn)行管理時(shí),可能會(huì)增加應(yīng)用程序的復(fù)雜性。要保持簡單,可能要在DataSet中為每個(gè)DataTable創(chuàng)建一個(gè)DataAdapter。

用多個(gè)表填充DataSet

如果使用批處理SQL語句檢索多個(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");

來自Customers表的數(shù)據(jù)放在名為“Customers”的DataTable中。來自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的常見問題。

1) 在訪問相關(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)程訪問DataReader。DataReader是為已連接好的數(shù)據(jù)訪問設(shè)計(jì)的。

2) 當(dāng)訪問列數(shù)據(jù)時(shí),使用類型化訪問器,例如,GetString、GetInt32等。這使您不用進(jìn)行將GetValue返回的Object強(qiáng)制轉(zhuǎn)換成特定類型所需的處理。

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ī)訪問列。如果不需要這種隨機(jī)訪問,為了提高性能,就將CommandBehavior.SequentialAccess傳遞給ExecuteReader調(diào)用。這將DataReader的默認(rèn)行為更改為僅在請(qǐng)求時(shí)將數(shù)據(jù)加載到內(nèi)存。注意,CommandBehavior.SequentialAccess要求順序訪問返回的列。也就是說,一旦讀過返回的列,就不能再讀它的值了。

5) 如果已經(jīng)完成讀取來自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而使大量內(nèi)存被用光。SequentialAccess將DataReader的行為設(shè)置為只加載請(qǐng)求的數(shù)據(jù)。然后還可以使用GetBytes或GetChars控制每次加載多少數(shù)據(jù)。

記住,使用SequentialAccess時(shí),不能不按順序訪問DataReader返回的不同字段。也就是說,如果查詢返回三列,其中第三列是BLOB,并且想訪問前兩列中的數(shù)據(jù),就必須在訪問BLOB數(shù)據(jù)之前先訪問第一列的值,然后訪問第二列的值。這是因?yàn)楝F(xiàn)在數(shù)據(jù)是順序返回的,并且DataReader一旦讀過該數(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語法使用CommandType.Text調(diào)用存儲(chǔ)過程。使用CommandType.StoredProcedure只是秘密地生成ODBC CALL語法。

2) 一定要設(shè)置OleDbParameter的類型、大小(如果適用)、以及精度和范圍(如果參數(shù)類型是numeric或decimal)。注意,如果不顯式提供參數(shù)信息,OleDbCommand會(huì)為每個(gè)執(zhí)行命令重新創(chuàng)建OLE DB參數(shù)訪問器。

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

使用SqlCommand執(zhí)行存儲(chǔ)過程的快速提示:如果調(diào)用存儲(chǔ)過程,將SqlCommand的CommandType屬性指定為StoredProcedure的CommandType。這樣通過將該命令顯式標(biāo)識(shí)為存儲(chǔ)過程,就不需要在執(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ù)

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

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

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

分享:怎樣在ASP.NET中備份SQL Server數(shù)據(jù)庫
前言:我們?cè)陂_發(fā)網(wǎng)站時(shí),在管理后臺(tái),管理員通常要定期對(duì)數(shù)據(jù)庫進(jìn)行備份(當(dāng)然也可以讓sqlserver服務(wù)器定期自動(dòng)備份,但我此處講的是asp.net中的備份),備份的代碼很簡單: 下面是我做一個(gè)網(wǎng)站后臺(tái)時(shí)在備份按扭下寫的一個(gè)事件: protected void Button1_Click(objec

共2頁上一頁12下一頁
來源:模板無憂//所屬分類:.Net教程/更新時(shí)間:2009-03-15
相關(guān).Net教程
久久青青草视频| 日韩在线卡一卡二| 亚洲欧洲制服丝袜| 中文字幕亚洲欧美日韩高清| 五月婷婷激情综合| 国产精品91久久久久久| 黄色av免费观看| 亚洲综合欧美激情| 久久在线精品| 91在线短视频| 日韩性xxxx| 久久99国产综合精品女同| 无码少妇一区二区| 日韩美女在线视频| 欧美色图另类小说| 精品99久久久久成人网站免费| 久久婷婷国产综合精品青草| 久久久精品国产| 精品在线播放免费| 欧美国产综合在线| 中文字幕欧美一区| 亚洲 小说 欧美 激情 另类| 欧美日韩一区综合| 日韩电影大片中文字幕| 国产女同性恋一区二区| 国产高清精品软件丝瓜软件| 欧美精品一区二区三区在线四季| 三级精品在线观看| 精品毛片久久久久久| 成人性视频免费网站| 亚洲av无码国产精品久久| 国产成人av电影在线| 久久在精品线影院精品国产| 黄色片免费网址| 久久久精品免费观看| 超碰97av在线| 免费av在线一区| 日韩成人精品视频| 国产精品网站免费| 91在线视频成人| 欧美乱大交做爰xxxⅹ性3| 亚洲免费成人av| 亚洲成熟女性毛茸茸| 国产女教师bbwbbwbbw| 色妹子一区二区| 中文字幕免费高清| 国产精品麻豆va在线播放| 另类专区欧美蜜桃臀第一页| 亚洲高清久久网| 在线观看av免费观看| 国产精品久久二区二区| 亚洲精品天堂网| 成人av资源网| 一区二区三区在线视频播放| 99热在线观看免费精品| 欧美性天天影院| 亚洲美女偷拍久久| 免费无码毛片一区二区app| 色综合五月天导航| 深夜福利视频网站| 国产日本欧美在线| 91久久精品一区二区三区| 欧美午夜精品久久久久久蜜| 日韩高清不卡在线| 成人激情免费在线| 久久综合伊人| 全网免费在线播放视频入口| 国产精品第二页| 亚洲成人久久影院| 视频一区视频二区在线观看| 999这里只有精品| 黄色一级二级三级| 超级碰在线观看| 欧洲永久精品大片ww免费漫画| 国产精品色婷婷久久58| 免费在线观看成年人视频| 国产精品流白浆视频| 亚洲综合精品自拍| 天天做天天爱夜夜爽| 亚洲一区二区在线视频| 中文字幕在线综合| 欧美午夜xxx| 美女脱光内衣内裤| 日韩a级黄色片| 亚洲欧美日韩视频一区| 丁香婷婷综合色啪| 日韩伦理在线视频| 久久黄色免费网站| 精品在线视频免费| 久久99精品波多结衣一区| 欧美一级特黄视频| 亚洲最大免费视频| 色乱码一区二区三在线看| 91久久线看在观草草青青| 久久精品久久综合| 加勒比在线一区| 欧美色欧美亚洲另类七区| 亚洲h精品动漫在线观看| 日韩在线视频观看免费| 天堂av资源网| 伊人网综合视频| 韩国一区二区三区美女美女秀| 日韩中文字幕在线视频| 波多野结衣黄色| 欧美风情第一页| 午夜福利123| 一本加勒比波多野结衣| 国产67194| 日韩黄色片网站| 自拍偷拍色综合| 黄色片网站在线免费观看| 日本黄色的视频| 国产情人节一区| 亚洲欧美在线免费| 亚洲天堂av线| www.亚洲在线| 日本精品在线免费观看| 日本欧美黄色片| 免费国产黄色网址| 欧美有码在线观看| 在线播放日韩导航| 一区二区三区精品在线观看| 艳妇乳肉豪妇荡乳xxx| 超碰在线公开97| 妺妺窝人体色777777| 国产一级黄色录像| 国产精品不卡av| 日韩中文字幕区一区有砖一区| 日本欧洲一区二区| 91在线视频播放地址| 久久资源在线| 亚洲最大成人网站| 国产人妻精品久久久久野外| 亚洲精品不卡| 国产精品自拍偷拍| 亚洲一二三区不卡| 亚洲三级电影网站| 色综合天天天天做夜夜夜夜做| 成人精品电影在线观看| 男人的天堂久久精品| www.爱爱.com| 国产精品黄色影片导航在线观看| 久久久av免费| 欧美乱妇高清无乱码| xxx一区二区| 日韩一中文字幕| 欧美在线激情视频| 影音先锋欧美精品| 欧美日韩第一区日日骚| 亚洲国产精品久久一线不卡| 亚洲一级黄色大片| 色噜噜噜噜噜噜| 日本女人高潮视频| 情事1991在线| 一区二区三区在线观看www| 精品国产_亚洲人成在线| 91精品国产一区| 国产欧美一区二区精品忘忧草| 成人爽a毛片一区二区| 免费国偷自产拍精品视频| 美女露出粉嫩尿囗让男人桶| 波多野结衣在线网址| 99久久免费国产| 深爱五月综合网| 秋霞网一区二区三区| 91亚洲国产成人久久精品麻豆| 国产又粗又猛视频| 亚洲一级片免费看| 久草国产精品视频| 最近中文字幕免费观看| 国产无遮挡又黄又爽又色| 久久一区二区电影| 日韩少妇内射免费播放| 激情一区二区三区| 国产福利一区视频| 在线观看欧美一区| 国产高清www| 日本激情视频在线| 欧美日韩大片一区二区三区| 国产久一一精品| 国产专区欧美专区| 神马影院午夜我不卡影院| 午夜视频在线观看国产| 视频在线观看一区| 日韩一区二区三区三四区视频在线观看| 久久婷婷国产麻豆91天堂 | 国产精品一级黄片| 日韩女优在线视频| 国产又粗又长又硬| 91禁在线观看| 成人毛片在线免费观看| 亚洲黄网在线观看| 韩国av中文字幕| 成人高清视频在线| 精品国产sm最大网站免费看| 91精品国产综合久久蜜臀| 欧美高清精品3d| 性欧美视频videos6一9| 亚洲第一成年网| 欧美日韩在线播放| 欧美激情综合色综合啪啪五月| 天堂社区 天堂综合网 天堂资源最新版 | 国产精品日日摸夜夜摸av| 欧美三级中文字幕在线观看| 日韩国产一区三区| 91av视频在线免费观看| 精品免费国产| 老司机av网站| 青青青在线免费观看| 第四色在线视频| 佐佐木明希电影| 日韩成人av一区二区| 亚洲一级Av无码毛片久久精品| 国产成人av影视| 欧美日韩偷拍视频| 捆绑调教美女网站视频一区| 丁香天五香天堂综合| 欧美亚洲图片小说| 久久久成人av| 91成人破解版| 一区二区三区不卡视频在线观看| 国产免费久久av| 美女伦理水蜜桃4| 国产人成亚洲第一网站在线播放| 亚洲h动漫在线| 亚洲天天在线日亚洲洲精| 欧美激情三级免费| 两根大肉大捧一进一出好爽视频| 中文字幕一区二区人妻电影丶| 青青草国产精品亚洲专区无| 国产精品一区二区免费不卡| 亚洲色图制服诱惑| 亚洲激情自拍图| 成人亚洲视频在线观看| 草逼视频免费看| 亚洲色图欧美偷拍| 九九热这里只有精品免费看| 你真棒插曲来救救我在线观看| 99精品视频网站| 国产毛片aaa| 成人精品鲁一区一区二区| 国产成人一区二区三区小说| 中文字幕91视频| 日韩三级.com| 久久久999免费视频| caopeng视频| 亚洲国产精品v| 日韩亚洲欧美成人| 91福利国产成人精品播放| 亚洲天堂日韩av| 国产精品传媒视频| 自拍偷拍亚洲在线| 艹b视频在线观看| 无码人妻精品一区二区三应用大全| 日本一本高清视频| 国产一区在线观看麻豆| 国产精品一区二区三| 黄色片网站在线播放| 懂色av一区二区在线播放| 日韩电影中文 亚洲精品乱码| 日韩精品视频一区二区在线观看| 欧美韩国日本在线| 中文乱码字幕高清一区二区| 国产三级精品视频| 91牛牛免费视频| 丰满人妻一区二区三区无码av| 国内精品视频在线| 男女羞羞免费视频| 日韩一区二区在线看片| 日本网站在线看| av电影在线观看完整版一区二区| 欧美激情手机在线视频 | 亚洲精品日韩av| 国产亚洲欧美久久久久 | 日韩三级av在线播放| 国产成人精品福利一区二区三区| 国产又粗又大又爽视频| 亚洲第一级黄色片| 99国产精品白浆在线观看免费| 青青草免费观看视频| 欧美性xxxx极品hd满灌| 国产精品一区二区免费看| 亚洲欧美日韩综合一区| 18深夜在线观看免费视频| 激情五月播播久久久精品| 亚洲精品国产精品久久| 国产福利在线导航| 人妻一区二区三区| 玉足女爽爽91| 欧美精品免费播放| 国产精品波多野结衣| 日韩女同一区二区三区| 日韩电影在线看| 疯狂蹂躏欧美一区二区精品| 国产精品久久..4399| 久久精品aⅴ无码中文字字幕重口| 免费看一级大片| 久久久久久久高潮| 亚洲成人资源网| 日韩美女免费视频| 日韩中文字幕二区| 亚洲丝袜av一区| 亚洲一区在线观看网站| 欧美多人乱p欧美4p久久| 四虎永久免费网站| 青春草免费视频| 99精品热视频| 久久精品国产成人| 国产精品一二三在线观看| 日本 欧美 国产| 国产亚洲欧美色| 欧美黑人性视频| 午夜精品久久久久久久无码| 亚洲高清在线看| 国产精品欧美一级免费| 欧美一区深夜视频| 日韩一级性生活片| 黄色免费看视频| 免费人成黄页网站在线一区二区| 欧美一级专区免费大片| 一区二区三区国| 国产手机在线视频| 亚洲综合丁香婷婷六月香| 久久久久久久久久久av| 日韩在线一区视频| 成人一区二区三区| 久久久999成人| 国产一级片自拍| 日本女人一区二区三区| 精品日韩欧美在线| 天堂av在线中文| 国产精品亚洲一区| aaaaa黄色片| 日本女人一区二区三区| 亚洲国产精品久久久| www.中文字幕在线| 人人超碰91尤物精品国产| 亚洲美女福利视频网站| 色一情一乱一伦一区二区三区日本 | 色欲久久久天天天综合网| 精品偷拍各种wc美女嘘嘘| 中文字幕av不卡在线| 日韩主播视频在线| 国内自拍欧美激情| chinese少妇国语对白| 国产又粗又长视频| 日韩一卡二卡三卡| 国产性xxxx18免费观看视频| 久久青草久久| 久久久免费在线观看| 国产精品三级在线观看无码| 亚洲精品免费看| 国产精品乱码视频| 国产原创视频在线| 欧美视频精品在线| 波多野结衣家庭教师视频| 麻豆精品新av中文字幕| 2020久久国产精品| 精品无码免费视频| 欧美日韩一级二级三级| 最新国产精品久久| 国产精品国产精品国产专区不卡| 视色视频在线观看| 欧美高清在线精品一区| 免费亚洲精品视频| 日韩一级片免费看| 欧美一区二区.| 亚洲第一精品在线观看| 亚洲电影免费观看高清| 一级黄色免费视频| 黄色成人在线播放| 在线观看亚洲色图| 国产.精品.日韩.另类.中文.在线.播放| av免费精品一区二区三区| 国产一级片免费视频| 日韩一区二区三区三四区视频在线观看| 亚洲熟妇av一区二区三区漫画| 欧美激情综合在线| 欧美日韩一区二区三区在线观看免| 高清国产mv在线观看| 国产精品久久久久一区二区| a天堂中文在线观看| 国产大片精品免费永久看nba| 中文字幕 人妻熟女| 亚洲一区二区国产| 国产第一页第二页| 最近2019年中文视频免费在线观看| 9.1片黄在线观看| www亚洲欧美| 伊人中文字幕在线观看| 不卡av日日日| 免费观看a视频| 国产日韩欧美另类| 亚洲av无码一区二区三区性色| 极品少妇xxxx精品少妇偷拍 | 欧美 日韩 国产一区| 欧美激情一区二区三区蜜桃视频| 成人在线免费观看视频网站| 国产欧美日韩久久| 国产伦精品免费视频| 国产精品久久久999| 国产美女无遮挡永久免费| 国产精品视频精品视频| 日韩不卡手机在线v区| 国产精品99久久久久久久| 国产成人在线电影| 亚洲在线色站| 午夜伊人狠狠久久| 一级网站在线观看| 51久久夜色精品国产麻豆|