真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ADO.NET如何連接

這篇文章給大家分享的是有關(guān)ADO.NET如何連接的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

創(chuàng)新互聯(lián)公司10多年成都企業(yè)網(wǎng)站定制服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計及高端網(wǎng)站定制服務(wù),成都企業(yè)網(wǎng)站定制及推廣,對成都水泥攪拌車等多個行業(yè)擁有多年的網(wǎng)站制作經(jīng)驗的網(wǎng)站建設(shè)公司。

1.連接

在創(chuàng)建 LINQ to SQL DataContext 時,可以提供現(xiàn)有 ADO.NET連接。對 DataContext 的所有操作(包括查詢)都使用所提供的這個連接。如果此連接已經(jīng)打開,則在您使用完此連接時,LINQ to SQL 會保持它的打開狀態(tài)不變。我們始終可以訪問此連接,另外還可以使用 Connection 屬性自行關(guān)閉它。

//新建一個標準的ADO.NET連接:  SqlConnection nwindConn = new SqlConnection(connString);  nwindConn.Open();  // ... 其它的ADO.NET數(shù)據(jù)操作代碼... //  //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個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();

語句描述:這個例子使用預(yù)先存在的ADO.NET連接創(chuàng)建Northwind對象,本例中的查詢返回運費至少為500.00 的所有訂單。

2.事務(wù)

當我們已經(jīng)啟動了自己的數(shù)據(jù)庫事務(wù)并且我們希望DataContext 包含在內(nèi)時,我們可以向 DataContext 提供此事務(wù)。
通過 .NET Framework 創(chuàng)建事務(wù)的***方法是使用 TransactionScope 對象。通過使用此方法,我們可以創(chuàng)建跨數(shù)據(jù)庫及其他駐留在內(nèi)存中的資源管理器執(zhí)行的分布式事務(wù)。事務(wù)范圍幾乎不需要資源就可以啟動。它們僅在事務(wù)范圍內(nèi)存在多個連接時才將自身提升為分布式事務(wù)。

using (TransactionScope ts = new TransactionScope())  {  db.SubmitChanges();  ts.Complete();  }

注意:不能將此方法用于所有數(shù)據(jù)庫。例如,SqlClient 連接在針對 SQL Server 2000 服務(wù)器使用時無法提升系統(tǒng)事務(wù)。它采取的方法是,只要它發(fā)現(xiàn)有使用事務(wù)范圍的情況,它就會自動向完整的分布式事務(wù)登記。

下面用一個例子說明一下事務(wù)的使用方法。在這里,也說明了重用 ADO.NET 命令和 DataContext 之間的同一連接。

var q =  from p in db.Products  where p.ProductID == 3  select p;  //使用LINQ to SQL查詢出來  //新建一個標準的ADO.NET連接:  SqlConnection nwindConn = new SqlConnection(connString);  nwindConn.Open();  //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個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;//這有一個錯誤,不能為負數(shù)  interop_db.SubmitChanges();  nwindTxn.Commit();  }  catch (Exception e)  {  //如果有一個錯誤,所有的操作回滾  Console.WriteLine(e.Message);  }  nwindConn.Close();

語句描述:這個例子使用預(yù)先存在的 ADO.NET連接創(chuàng)建 Northwind 對象,然后與此對象共享一個 ADO.NET 事務(wù)。此事務(wù)既用于通過 ADO.NET連接執(zhí)行 SQL 命令,又用于通過 Northwind 對象提交更改。當事務(wù)因違反 CHECK 約束而中止時,將回滾所有更改,包括通過 SqlCommand 做出的更改,以及通過Northwind 對象做出的更改。

感謝各位的閱讀!關(guān)于“ADO.NET如何連接”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!


本文標題:ADO.NET如何連接
文章路徑:http://weahome.cn/article/jeohcc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部