日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

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

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

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

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

但是,每次用到這些特性,都會(huì)有性能損失。建議將這些特性主要用于設(shè)計(jì)時(shí)和即席應(yīng)用程序中。在可能的情況下,顯式指定架構(gòu)和元數(shù)據(jù)。其中包括在DataSet中定義表和列、定義DataAdapter的Command屬性、以及為Command定義Parameter信息。

ExecuteScalar和ExecuteNonQuery

如果想返回像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ù)值是否“等于”空。相反,需要寫(xiě)一個(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ì)象打開(kāi)一次連接,但是在多個(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)打開(kāi)為相關(guān)命令屬性指定的連接。如果Fill或Update方法打開(kāi)了連接,F(xiàn)ill或Update將在操作完成的時(shí)候關(guān)閉它。為了獲得最佳性能,僅在需要時(shí)將與數(shù)據(jù)庫(kù)的連接保持為打開(kāi)。同時(shí),減少打開(kāi)和關(guān)閉多操作連接的次數(shù)。

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

另外,當(dāng)執(zhí)行事務(wù)時(shí),顯式地在開(kāi)始事務(wù)之前打開(kāi)連接,并在提交之后關(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

完成對(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方法。

在C#中使用“Using”語(yǔ)句

對(duì)于C#程序員來(lái)說(shuō),確保始終關(guān)閉Connection和DataReader對(duì)象的一個(gè)方便的方法就是使用using語(yǔ)句。using語(yǔ)句在離開(kāi)自己的作用范圍時(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)打開(kāi),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)聽(tīng)OleDbConnection的StateChange事件可能會(huì)使應(yīng)用程序的性能好一些。

與XML集成

ADO.NET在DataSet中提供了廣泛的XML集成,并公開(kāi)了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)寫(xiě)為XSD架構(gòu)。

5) 將DataSet的內(nèi)容寫(xiě)為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框架中有一些類,公開(kāi)用于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ò)鏈接X(jué)ML for Microsoft SQL Server 2000 Web Release 2 (SQLXML 2.0)

更多有用的技巧

下面是一些編寫(xiě)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開(kāi)始,并且以正階值遞增。因此,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)增量的列所必需的額外工作。

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

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

在測(cè)試開(kāi)放式并發(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è)閱讀器是線程安全的。但是,在寫(xiě)的時(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ì)需求。

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

共2頁(yè)上一頁(yè)12下一頁(yè)
來(lái)源:模板無(wú)憂//所屬分類:.Net教程/更新時(shí)間:2009-03-15
相關(guān).Net教程