這篇文章給大家分享的是有關(guān)ADO.NET如何連接的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)公司10多年成都企業(yè)網(wǎng)站定制服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計(jì)及高端網(wǎng)站定制服務(wù),成都企業(yè)網(wǎng)站定制及推廣,對(duì)成都水泥攪拌車等多個(gè)行業(yè)擁有多年的網(wǎng)站制作經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。
1.連接
在創(chuàng)建 LINQ to SQL DataContext 時(shí),可以提供現(xiàn)有 ADO.NET連接。對(duì) DataContext 的所有操作(包括查詢)都使用所提供的這個(gè)連接。如果此連接已經(jīng)打開,則在您使用完此連接時(shí),LINQ to SQL 會(huì)保持它的打開狀態(tài)不變。我們始終可以訪問此連接,另外還可以使用 Connection 屬性自行關(guān)閉它。
//新建一個(gè)標(biāo)準(zhǔn)的ADO.NET連接: SqlConnection nwindConn = new SqlConnection(connString); nwindConn.Open(); // ... 其它的ADO.NET數(shù)據(jù)操作代碼... // //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個(gè)DataContext: Northwind interop_db = new Northwind(nwindConn); var orders = from o in interop_db.Orders where o.Freight > 500.00M select o; //返回Freight>500.00M的訂單 nwindConn.Close();
語句描述:這個(gè)例子使用預(yù)先存在的ADO.NET連接創(chuàng)建Northwind對(duì)象,本例中的查詢返回運(yùn)費(fèi)至少為500.00 的所有訂單。
2.事務(wù)
當(dāng)我們已經(jīng)啟動(dòng)了自己的數(shù)據(jù)庫事務(wù)并且我們希望DataContext 包含在內(nèi)時(shí),我們可以向 DataContext 提供此事務(wù)。
通過 .NET Framework 創(chuàng)建事務(wù)的***方法是使用 TransactionScope 對(duì)象。通過使用此方法,我們可以創(chuàng)建跨數(shù)據(jù)庫及其他駐留在內(nèi)存中的資源管理器執(zhí)行的分布式事務(wù)。事務(wù)范圍幾乎不需要資源就可以啟動(dòng)。它們僅在事務(wù)范圍內(nèi)存在多個(gè)連接時(shí)才將自身提升為分布式事務(wù)。
using (TransactionScope ts = new TransactionScope()) { db.SubmitChanges(); ts.Complete(); }
注意:不能將此方法用于所有數(shù)據(jù)庫。例如,SqlClient 連接在針對(duì) SQL Server 2000 服務(wù)器使用時(shí)無法提升系統(tǒng)事務(wù)。它采取的方法是,只要它發(fā)現(xiàn)有使用事務(wù)范圍的情況,它就會(huì)自動(dòng)向完整的分布式事務(wù)登記。
下面用一個(gè)例子說明一下事務(wù)的使用方法。在這里,也說明了重用 ADO.NET 命令和 DataContext 之間的同一連接。
var q = from p in db.Products where p.ProductID == 3 select p; //使用LINQ to SQL查詢出來 //新建一個(gè)標(biāo)準(zhǔn)的ADO.NET連接: SqlConnection nwindConn = new SqlConnection(connString); nwindConn.Open(); //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個(gè)DataContext: Northwind interop_db = new Northwind(nwindConn); SqlTransaction nwindTxn = nwindConn.BeginTransaction(); try { SqlCommand cmd = new SqlCommand("UPDATE Products SET" +"QuantityPerUnit = 'single item' WHERE ProductID = 3"); cmd.Connection = nwindConn; cmd.Transaction = nwindTxn; cmd.ExecuteNonQuery(); interop_db.Transaction = nwindTxn; Product prod1 = interop_db.Products.First(p => p.ProductID == 4); Product prod2 = interop_db.Products.First(p => p.ProductID == 5); prod1.UnitsInStock -= 3; prod2.UnitsInStock -= 5;//這有一個(gè)錯(cuò)誤,不能為負(fù)數(shù) interop_db.SubmitChanges(); nwindTxn.Commit(); } catch (Exception e) { //如果有一個(gè)錯(cuò)誤,所有的操作回滾 Console.WriteLine(e.Message); } nwindConn.Close();
語句描述:這個(gè)例子使用預(yù)先存在的 ADO.NET連接創(chuàng)建 Northwind 對(duì)象,然后與此對(duì)象共享一個(gè) ADO.NET 事務(wù)。此事務(wù)既用于通過 ADO.NET連接執(zhí)行 SQL 命令,又用于通過 Northwind 對(duì)象提交更改。當(dāng)事務(wù)因違反 CHECK 約束而中止時(shí),將回滾所有更改,包括通過 SqlCommand 做出的更改,以及通過Northwind 對(duì)象做出的更改。
感謝各位的閱讀!關(guān)于“ADO.NET如何連接”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
網(wǎng)頁題目:ADO.NET如何連接
文章地址:http://m.kartarina.com/article22/jeohcc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、網(wǎng)站維護(hù)、服務(wù)器托管、標(biāo)簽優(yōu)化、建站公司、企業(yè)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)