ef core的外键约束笔记

ef core设置可选外键,有如下几种方式:
1、在依赖实体AAA中,并不显式设置外键属性XXXId

2、手动设置外键属性XXXId为可空类型(int?等类型)

3、在实体类与数据表进行映射时,配置狭隘属性的方式配置可选外键
builder.Property<int?>("XXXId")

4、可以在依赖实体中定义外键属性的前提下手动配置映射关系关联是否可空
builder.HangMany(m=> m.AAA).WithOne(o => o.XXX).IsRequest(false)
默认不配置IsRequest,且其默认参数为true,为必选

5、我们可以在映射时配置SetNull作为删除枚举,但是数据库必须支持这一点,并且这样配置数据库可能会导致其他限制,实际上使用此选项通常不切合实际,因此不推荐使用SetNull作为可选外键属性默认删除枚举

同时建议去看下ef core官方的代码示例:

https://github.com/aspnet/EntityFramework.Docs/blob/master/samples/core/Saving/Saving/CascadeDelete/Sample.cs

ef core官方关于外键级联的文档:

https://docs.microsoft.com/zh-cn/ef/core/saving/cascade-delete

上一篇:私有云方案——利用阿里云云解析实现DDNS


下一篇:PyQt5--基础篇:用eric6工具实现三级联动效果