![](/img/trans.png)
[英]How to properly control cascading deletion in EF Core using Fluent API?
[英]EF CORE - Fluent API - cascading delete restrict to on table
该模型:
public class AccountUser
{
public long AccountUserId { get; set; }
...
public long UserPermissionGroupId { get; set; }
public UserPermissionGroup UserPermissionGroup { get; set; }
}
public class UserPermissionGroup
{
public long UserPermissionGroupId { get; set; }
...
public string Name { get; set; }
}
问题:如何在表AccountUser-> UserPermissionGroup上设置外键以限制删除?
我找不到如何在删除操作上将外键设置为仅限于一个表的示例。 在此示例中,我不能使用WithMany / WithOne之类的东西,然后再使用OnDelete之类的东西https://docs.microsoft.com/zh-cn/ef/core/modeling/relationships#cascade-delete-1,因为我没有UserPermissionGroup的引用回到AccountUser。
非常感谢你。
在流畅的API中,您可以执行以下操作:
builder.Entity<AccountUser>()
.HasOne(a => a.UserPermissionGroup)
.WithOne().OnDelete(DeleteBehavior.Restrict);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.