日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
ADO.NET連接經(jīng)驗介紹

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

10年積累的成都網(wǎng)站設(shè)計、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設(shè)公司經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先做網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有景泰免費網(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 時,可以提供現(xiàn)有 ADO.NET連接。對 DataContext 的所有操作(包括查詢)都使用所提供的這個連接。如果此連接已經(jīng)打開,則在您使用完此連接時,LINQ to SQL 會保持它的打開狀態(tài)不變。我們始終可以訪問此連接,另外還可以使用 Connection 屬性自行關(guān)閉它。

 
 
 
  1. //新建一個標(biāo)準(zhǔn)的ADO.NET連接:  
  2. SqlConnection nwindConn = new SqlConnection(connString);  
  3. nwindConn.Open();  
  4. // ... 其它的ADO.NET數(shù)據(jù)操作代碼... //  
  5. //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個DataContext:  
  6. Northwind interop_db = new Northwind(nwindConn);  
  7. var orders =  
  8. from o in interop_db.Orders  
  9. where o.Freight > 500.00M  
  10. select o;  
  11. //返回Freight>500.00M的訂單  
  12. nwindConn.Close(); 

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

2.事務(wù)

當(dāng)我們已經(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ù)。

 
 
 
  1. using (TransactionScope ts = new TransactionScope())  
  2. {  
  3. db.SubmitChanges();  
  4. ts.Complete();  

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

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

 
 
 
  1. var q =  
  2. from p in db.Products  
  3. where p.ProductID == 3  
  4. select p;  
  5. //使用LINQ to SQL查詢出來  
  6. //新建一個標(biāo)準(zhǔn)的ADO.NET連接:  
  7. SqlConnection nwindConn = new SqlConnection(connString);  
  8. nwindConn.Open();  
  9. //利用現(xiàn)有的ADO.NET連接來創(chuàng)建一個DataContext:  
  10. Northwind interop_db = new Northwind(nwindConn);  
  11. SqlTransaction nwindTxn = nwindConn.BeginTransaction();  
  12. try  
  13. {  
  14. SqlCommand cmd = new SqlCommand("UPDATE Products SET"  
  15. +"QuantityPerUnit = 'single item' WHERE ProductID = 3");  
  16. cmd.Connection = nwindConn;  
  17. cmd.Transaction = nwindTxn;  
  18. cmd.ExecuteNonQuery();  
  19. interop_db.Transaction = nwindTxn;  
  20. Product prod1 = interop_db.Products.First(p => p.ProductID == 4);  
  21. Product prod2 = interop_db.Products.First(p => p.ProductID == 5);  
  22. prod1.UnitsInStock -3;  
  23. prod2.UnitsInStock -5;//這有一個錯誤,不能為負數(shù)  
  24. interop_db.SubmitChanges();  
  25. nwindTxn.Commit();  
  26. }  
  27. catch (Exception e)  
  28. {  
  29. //如果有一個錯誤,所有的操作回滾  
  30. Console.WriteLine(e.Message);  
  31. }  
  32. nwindConn.Close(); 

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


分享題目:ADO.NET連接經(jīng)驗介紹
鏈接URL:http://www.5511xx.com/article/cdcpedd.html