使用 LINQ 執行直接更新而無需選擇查詢
LINQ 允許透過利用延遲執行來更有效地進行資料庫操作。特別是,它支援直接更新,而不需要 SELECT 語句明確檢索資料。
為了實現這一點,LINQ 可以僅根據您對實體物件所做的變更產生更新命令。請考慮以下範例:
using System; using System.Linq; using System.Data.Linq; namespace LinqUpdateDemo { class Program { static void Main(string[] args) { // Create a DataContext DataContext dc = new DataContext(); // Attach an entity to the DataContext Foo foo = new Foo { FooId = 1 }; dc.Foos.Attach(foo); // Modify the entity foo.Name = "Updated Name"; // Submit the changes without a SELECT query dc.SubmitChanges(); } } public class Foo { public int FooId { get; set; } public string Name { get; set; } } }
在此範例中,LINQ 運算式直接產生針對資料庫的更新指令,而不執行 SELECT 查詢。這是透過以下方式實現的:
呼叫SubmitChanges() 後,LINQ 會根據foo 物件的變更生成SQL UPDATE 指令:
UPDATE Foos SET Name = 'Updated Name' WHERE FooId = 1
使用LINQ時,請記住資料檢索和修改是單獨的步驟。這樣可以避免向客戶端傳輸不必要的數據,從而實現高效操作。
以上是LINQ 如何在不使用 SELECT 查詢的情況下執行直接資料庫更新?的詳細內容。更多資訊請關注PHP中文網其他相關文章!