DataContext.GetChangeSet 方法

定義

取得 DataContext 所追蹤的已修改物件。

C#
public System.Data.Linq.ChangeSet GetChangeSet();

傳回

這組物件是以三個唯讀集合傳回。

範例

C#
Northwnd db = new Northwnd(@"c:\northwnd.mdf");

var custQuery =
    from cust in db.Customers
    where cust.City == "London"
    select cust;

foreach (Customer custObj in custQuery)
{
    Console.WriteLine("CustomerID: {0}", custObj.CustomerID);
    Console.WriteLine("\tOriginal value: {0}", custObj.City);
    custObj.City = "Paris";
    Console.WriteLine("\tUpdated value: {0}", custObj.City);
}

ChangeSet cs = db.GetChangeSet();
Console.Write("Total changes: {0}", cs);
// Freeze the console window.
Console.ReadLine();

db.SubmitChanges();

備註

請注意下列考量:

  • GetChangeSet 可能會有副作用,例如推斷通常會在 時 SubmitChanges執行的插入和刪除作業。 例如,下列作業中使用的物件可以在下列清單中建立對應的推斷作業:

  • 集合可能無法根據外鍵條件約束來排序。

  • 資料庫產生的值 (例如,無法使用主鍵和外鍵值、時間戳等等) 。 這類資訊需要資料庫命令執行,而且可能傳播擷取的資訊 (例如,主鍵的外鍵) 。

  • 呼叫時會計算一組已變更的物件。 如果進行其他變更,對的 SubmitChanges 後續呼叫可能會產生不同的集合。

未進行任何變更時輸出,如下所示:

{Added: 0, Removed: 0, Modified: 0}

適用於

產品 版本
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1