新聞中心
本文向大家介紹ADO.NET連接,可能好多人還不了解ADO.NET連接,沒(méi)有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。

10年積累的成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問(wèn)題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有景泰免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
LINQ to SQL基于由 ADO.NET 提供程序模型提供的服務(wù)。因此,我們可以將 LINQ to SQL 代碼與現(xiàn)有的 ADO.NET 應(yīng)用程序混合在一起,將當(dāng)前 ADO.NET 解決方案遷移到 LINQ to SQL。
1.連接
在創(chuàng)建 LINQ to SQL DataContext 時(shí),可以提供現(xiàn)有 ADO.NET連接。對(duì) DataContext 的所有操作(包括查詢)都使用所提供的這個(gè)連接。如果此連接已經(jīng)打開,則在您使用完此連接時(shí),LINQ to SQL 會(huì)保持它的打開狀態(tài)不變。我們始終可以訪問(wèn)此連接,另外還可以使用 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連接來(lái)創(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();
語(yǔ)句描述:這個(gè)例子使用預(yù)先存在的ADO.NET連接創(chuàng)建Northwind對(duì)象,本例中的查詢返回運(yùn)費(fèi)至少為500.00 的所有訂單。
2.事務(wù)
當(dāng)我們已經(jīng)啟動(dòng)了自己的數(shù)據(jù)庫(kù)事務(wù)并且我們希望DataContext 包含在內(nèi)時(shí),我們可以向 DataContext 提供此事務(wù)。
通過(guò) .NET Framework 創(chuàng)建事務(wù)的***方法是使用 TransactionScope 對(duì)象。通過(guò)使用此方法,我們可以創(chuàng)建跨數(shù)據(jù)庫(kù)及其他駐留在內(nèi)存中的資源管理器執(zhí)行的分布式事務(wù)。事務(wù)范圍幾乎不需要資源就可以啟動(dòng)。它們僅在事務(wù)范圍內(nèi)存在多個(gè)連接時(shí)才將自身提升為分布式事務(wù)。
- using (TransactionScope ts = new TransactionScope())
- {
- db.SubmitChanges();
- ts.Complete();
- }
注意:不能將此方法用于所有數(shù)據(jù)庫(kù)。例如,SqlClient 連接在針對(duì) SQL Server 2000 服務(wù)器使用時(shí)無(wú)法提升系統(tǒng)事務(wù)。它采取的方法是,只要它發(fā)現(xiàn)有使用事務(wù)范圍的情況,它就會(huì)自動(dòng)向完整的分布式事務(wù)登記。
下面用一個(gè)例子說(shuō)明一下事務(wù)的使用方法。在這里,也說(shuō)明了重用 ADO.NET 命令和 DataContext 之間的同一連接。
- var q =
- from p in db.Products
- where p.ProductID == 3
- select p;
- //使用LINQ to SQL查詢出來(lái)
- //新建一個(gè)標(biāo)準(zhǔn)的ADO.NET連接:
- SqlConnection nwindConn = new SqlConnection(connString);
- nwindConn.Open();
- //利用現(xiàn)有的ADO.NET連接來(lái)創(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();
語(yǔ)句描述:這個(gè)例子使用預(yù)先存在的 ADO.NET連接創(chuàng)建 Northwind 對(duì)象,然后與此對(duì)象共享一個(gè) ADO.NET 事務(wù)。此事務(wù)既用于通過(guò) ADO.NET連接執(zhí)行 SQL 命令,又用于通過(guò) Northwind 對(duì)象提交更改。當(dāng)事務(wù)因違反 CHECK 約束而中止時(shí),將回滾所有更改,包括通過(guò) SqlCommand 做出的更改,以及通過(guò)Northwind 對(duì)象做出的更改。
當(dāng)前名稱:ADO.NET連接經(jīng)驗(yàn)介紹
標(biāo)題來(lái)源:http://m.5511xx.com/article/cdcpedd.html


咨詢
建站咨詢
