EF Code First 主键对应多个外键
这是一位朋友提出的疑问,EF 映射主键可以对应多个外键吗?如果外键设置级联删除会发生什么情况?下面做一个测试,示例实体代码:
public class Blog
{
public Blog()
{
Post1s = new List<Post1>();
Post2s = new List<Post2>();
}
public int Id { get; set; }
public string Title { get; set; }
public string Url { get; set; }
public string Remark { get; set; }
public virtual List<Post1> Post1s { get; set; }
public virtual List<Post2> Post2s { get; set; }
}
public class Post1
{
public int Id { get; set; }
public int BlogId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public virtual Blog Blog { get; set; }
}
public class Post2
{
public int Id { get; set; }
public int BlogId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public virtual Blog Blog { get; set; }
}
Blog 作为主表,Post1 和 Post2 作为字表,对应关系是一对多,示例映射代码:
public DbSet<Blog> Blogs { get; set; }
public DbSet<Post1> Post1s { get; set; }
public DbSet<Post2> Post2s { get; set; }
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Blog>()
.HasKey(t => t.Id);
modelBuilder.Entity<Blog>()
.HasMany(t => t.Post1s)
.WithRequired()
.HasForeignKey(t => t.BlogId)
.WillCascadeOnDelete(true);
modelBuilder.Entity<Blog>()
.HasMany(t => t.Post2s)
.WithRequired()
.HasForeignKey(t => t.BlogId)
.WillCascadeOnDelete(true);
modelBuilder.Entity<Post1>()
.HasKey(t => t.Id);
modelBuilder.Entity<Post2>()
.HasKey(t => t.Id);
base.OnModelCreating(modelBuilder);
}
生成数据结构:

测试数据代码:
static void Main(string[] args)
{
using (var context=new BloggingContext())
{
//var blog = new Blog
//{
// Remark = "1",
// Title = "1",
// Url = "1"
//};
//blog.Post1s.Add(new Post1
//{
// Title = "1",
// Blog = blog,
// Content = "1"
//});
//blog.Post2s.Add(new Post2
//{
// Title = "1",
// Blog = blog,
// Content = "1"
//});
//context.Blogs.Add(blog);
var blog = context.Blogs.FirstOrDefault();
context.Blogs.Remove(blog);
context.SaveChanges();
Console.ReadKey();
}
}
测试结果我就不截图了,上面映射配置中,Blog 和 Post1、Post2 关系是一对多,并且级联删除,当我们添加 Blog 中的数据,Post1、Post2 也会自动生成对应的外键值,当我们删除 Blog 中的数据,外键对应 Post1、Post2 中的数据也会自动删除。
总的来说,EF Code First 主键对应多个外键?答案是:没什么问题。
作者:田园里的蟋蟀
微信公众号:你好架构
出处:http://www.cnblogs.com/xishuai/
公众号会不定时的分享有关架构的方方面面,包含并不局限于:Microservices(微服务)、Service Mesh(服务网格)、DDD/TDD、Spring Cloud、Dubbo、Service Fabric、Linkerd、Envoy、Istio、Conduit、Kubernetes、Docker、MacOS/Linux、Java、.NET Core/ASP.NET Core、Redis、RabbitMQ、MongoDB、GitLab、CI/CD(持续集成/持续部署)、DevOps等等。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。
微信公众号:你好架构
出处:http://www.cnblogs.com/xishuai/
公众号会不定时的分享有关架构的方方面面,包含并不局限于:Microservices(微服务)、Service Mesh(服务网格)、DDD/TDD、Spring Cloud、Dubbo、Service Fabric、Linkerd、Envoy、Istio、Conduit、Kubernetes、Docker、MacOS/Linux、Java、.NET Core/ASP.NET Core、Redis、RabbitMQ、MongoDB、GitLab、CI/CD(持续集成/持续部署)、DevOps等等。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构