溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linq中怎么調(diào)用SubmitChanges方法

發(fā)布時(shí)間:2021-08-11 15:37:02 來(lái)源:億速云 閱讀:247 作者:Leah 欄目:編程語(yǔ)言

本篇文章給大家分享的是有關(guān)Linq中怎么調(diào)用SubmitChanges方法,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

1. 當(dāng)Linq SubmitChanges方法時(shí),LINQ to SQL會(huì)檢查已知對(duì)象的集合以確定新實(shí)例是否已附加到它們。如果已附加,這些新實(shí)例將添加到被跟蹤對(duì)象的集合。
2. 所有具有掛起更改的對(duì)象將按照它們之間的依賴關(guān)系排序成一個(gè)對(duì)象序列。如果一個(gè)對(duì)象的更改依賴于其他對(duì)象,則這個(gè)對(duì)象將排在其依賴項(xiàng)之后。
3. 在即將傳輸任何實(shí)際更改時(shí),LINQ to SQL會(huì)啟動(dòng)一個(gè)事務(wù)來(lái)封裝由各條命令組成的系列。
4. 對(duì)對(duì)象的更改會(huì)逐個(gè)轉(zhuǎn)換為SQL命令,然后發(fā)送到服務(wù)器。

如果數(shù)據(jù)庫(kù)檢測(cè)到任何錯(cuò)誤,都會(huì)造成提交進(jìn)程停止并引發(fā)異常。將回滾對(duì)數(shù)據(jù)庫(kù)的所有更改,就像未進(jìn)行過(guò)提交一樣。DataContext 仍具有所有更改的完整記錄。

下面代碼說(shuō)明的是在數(shù)據(jù)庫(kù)中查詢CustomerID為ALFKI的顧客,然后修改其公司名稱,***次更新并Linq SubmitChanges方法,第二次更新了數(shù)據(jù)但并未Linq調(diào)用SubmitChanges方法。

//查詢  Customer cust = db.Customers.First(c => c.CustomerID == "ALFKI");  //更新數(shù)據(jù)并調(diào)用SubmitChanges()方法  cust.CompanyName = "YJingLee's Blog";  db.SubmitChanges();  //更新數(shù)據(jù)沒(méi)有調(diào)用SubmitChanges()方法  cust.CompanyName = "http://lyj.cnblogs.com";

動(dòng)態(tài)查詢

使用動(dòng)態(tài)查詢,這個(gè)例子用CreateQuery()方法創(chuàng)建一個(gè)IQueryable類(lèi)型表達(dá)式輸出查詢的語(yǔ)句。這里給個(gè)例子說(shuō)明一下。有關(guān)動(dòng)態(tài)查詢具體內(nèi)容,下一篇介紹。

var c1 = Expression.Parameter(typeof(Customer), "c");  PropertyInfo City = typeof(Customer).GetProperty("City");   var pred = Expression.Lambda<Func<Customer, bool>>(  Expression.Equal(  Expression.Property(c1, City),  Expression.Constant("Seattle")  }  };  IQueryable custs = db.Customers;  Expression expr = Expression.Call(typeof(Queryable), "Where",  new Type[] { custs.ElementType }, custs.Expression, pred);  IQueryable<Customer> q = db.Customers.AsQueryable().  Provider.CreateQuery<Customer>(expr);

Log屬性用于將SQL查詢或命令打印到TextReader。此方法對(duì)了解 LINQ to SQL 功能和調(diào)試特定的問(wèn)題可能很有用。

下面的示例使用Log屬性在SQL代碼執(zhí)行前在控制臺(tái)窗口中顯示此代碼。我們可以將此屬性與查詢、插入、更新和刪除命令一起使用。

//關(guān)閉日志功能  //db.Log = null;  //使用日志功能:日志輸出到控制臺(tái)窗口  db.Log = Console.Out;  var q = from c in db.Customers  where c.City == "London"  select c;  //日志輸出到文件  StreamWriter sw = new StreamWriter(Server.MapPath("log.txt"), true);  db.Log = sw;  var q = from c in db.Customers  where c.City == "London"  select c;  sw.Close();

以上就是Linq中怎么調(diào)用SubmitChanges方法,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見(jiàn)到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI