Entity Framework 中一對零或一關係的級聯刪除
最近遇到的一個場景中,在兩個 POCO 類別 User 和 UserDetail 之間建立了一對零或一的關係。但是,嘗試刪除 User 記錄時,由於缺少級聯刪除,UserDetail 中的外鍵約束阻止了 User 記錄的刪除。
為了解決這個問題,必須在 DbContext 中使用 Fluent API。應該要加入以下程式碼片段:
<code class="language-csharp">protected override void OnModelCreating(DbModelBuilder modelBuilder) { modelBuilder.Entity<User>() .HasOptional(a => a.UserDetail) .WithOptionalDependent() .WillCascadeOnDelete(true); }</code>
透過使用 HasOptional()
和 WithOptionalDependent()
方法,建立了 User 和 UserDetail 之間的一對零或一的關係。 WillCascadeOnDelete(true)
方法隨後為此關係啟用了級聯刪除。
實現這些變更後,刪除 User 記錄現在將自動觸發相關 UserDetail 記錄的刪除。
以上是如何在實體框架中實現一對零或一關係的級聯刪除?的詳細內容。更多資訊請關注PHP中文網其他相關文章!