默认情况下CodeFirst会在外键约束中设置 删除规则 为级联(不会默认设置 更新规则 为级联)
当仅定义了导航属性如
public virtual Manager Manager { get; set; }
而没有显示定义外键如
public int ManagerID { get; set; }
CodeFirst不会设置 删除规则 为级联
在显示定义外键属性的情况下,级联删除的关闭,可以通过Fluent API进行
modelBuilder.Entity<Department>().HasRequired(m => m.Manager).WithMany(n => n.Departments).HasForeignKey(m => m.ManagerID).WillCascadeOnDelete(false);
CodeFirst默认开启级联删除,考虑到EF中的级联删除并不常用,所以可以在OnModelCreating方法中使用Fluent API关掉所有主外键关系的级联删除
modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();
如果需要再使用.WillCascadeOnDelete(true) 单独打开某个主外键的级联删除
CodeFirst中,默认生成的数据表中外键字段不允许Null值,这样,就不能通过赋外键字段为Null值来解除关联关系,通过FluentAPI,可以修改外键字段为允许Null值
modelBuilder.Entity<Department>().HasOptional(m => m.Manager).WithMany(n => n.Departments);
参考资料
EntityFramework级联删除的操作方式 - 我的专栏 - 博客频道 - youkuaiyun.com
http://blog.youkuaiyun.com/applewangpai/article/details/17397349
EF学习杂记33:EF中的级联删除是怎么运作的 - Bruse - 博客园
http://www.cnblogs.com/brusehht/archive/2010/08/26/1809055.html
EF里单个实体的增查改删以及主从表关联数据的各种增删改查 - lonelyxmas - 博客园
http://www.cnblogs.com/lonelyxmas/p/3567529.html
EF里一对一、一对多、多对多关系的配置和级联删除 - 心态要好 - 博客园
http://www.cnblogs.com/oppoic/p/ef_one-to-one_one-to-many_many-to-many_cascadedelete.html