了解實體框架的預設行為:子物件持久化
在利用實體框架(EF) 時,一種廣泛採用的對象關係映射(ORM) ) .NET 框架,了解其有關子實體的行為至關重要。預設情況下,EF 假定儲存實體時,任何關聯的子物件都應與其一起儲存。但是,此預設操作可能會導致不必要的後果,特別是如果您打算跳過子實體持久化。
從持久化中排除子實體的原因
您可能會遇到以下情況不希望保存子實體的情況。例如,當從外部來源(例如平面文件)手動填入資料時,資料庫中的現有實體可能已經履行了子實體的角色。將重複項插入資料庫可能會導致不一致和完整性問題。此外,在為子實體分配主鍵之前保存子實體可能會妨礙 EF 的正常操作。
強制選擇性持久化:未更改的 EntityState
解決跳過子實體持久化的挑戰,您可以利用 EntityState.Unchanged 選項。透過明確將子實體的狀態設為 Unchanged,您可以指示 EF 在儲存作業期間忽略它。
使用EntityState.Unchanged 的程式碼範例
考慮以下內容程式碼範例,假設您有一個帶有City 子實體的School 實體:
public School Insert(School newItem) { using (var context = new DatabaseContext()) { context.Set<School>().Add(newItem); context.Entry(newItem.City).State = EntityState.Unchanged; context.SaveChanges(); return newItem; } }
透過設定City當實體的狀態為Unchanged 時,EF會將其從保存操作中排除,使資料庫保持不變。但是,這種方法需要手動處理子實體的分配。
替代解決方案:利用外鍵
更優雅和靈活的解決方案涉及利用外鍵。透過在子實體中定義外鍵屬性,您可以明確指定其與父實體的關係。然後,EF 將根據提供的參考自動處理關聯實體的狀態。
使用外鍵的程式碼範例
這裡是先前使用外鍵的程式碼範例的更新版本:
public class School { public int Id { get; set; } public string Name { get; set; } [ForeignKey("City_Id")] public City City { get; set; } [Required] public int City_Id { get; set; } } public School Insert(School newItem, int cityId) { using (var context = new DatabaseContext()) { // Set child entity to null to prevent insertion newItem.City = null; // Specify foreign key relationship without adding the child entity newItem.City_Id = cityId; context.Set<School>().Add(newItem); context.SaveChanges(); return newItem; } }
在這種情況下,您手動設定City_Id 並取消City 引用,指示EF透過外鍵建立連線而不涉及子實體。這種方法簡化了程式碼,避免了手動管理 EntityState 的需求。
結論
了解實體框架的預設行為並採用適當的技術(例如EntityState.Unchanged 或利用外鍵),使開發人員能夠控制和自訂子實體持久性,防止不必要的副作用並確保應用程式內的數據完整性。
以上是如何控制實體框架中子實體的持久性?的詳細內容。更多資訊請關注PHP中文網其他相關文章!