微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何将 EF6 MapKey 物化为实际的 C# 模型

如何解决如何将 EF6 MapKey 物化为实际的 C# 模型

我使用 EF6。我有三个实体(为了清楚起见省略了一些字段)

  1. 数据库用户

    [Table("Users")]
    public class DbUser
    {
        [Key] public Guid UserId { get; set; }
        public List<DbSeries> UserSeries { get; set; }
        public List<DbPlot> Plots { get; set; }
    }
    
  2. 数据库系列:

    [Table("Series")]
    public class DbSeries
    {
        [Key] public Guid SeriesId { get; set; }        
        public DbPlot ThermalPlot { get; set; }
    }
    
  3. DbPlot:

    [Table("Plots")]
    public class DbPlot
    {
        [Key] public Guid PlotId { get; set; }
    
        public Guid CurrentUserId { get; set; }
        public DbUser CurrentUser { get; set; }
        public virtual DbSeries Series { get; set; }
    }
    

他们的关系配置如下:

modelBuilder.Entity<DbUser>()
            .HasMany(s => s.UserSeries)
            .Withrequired(g => g.CurrentUser)
            .HasForeignKey(s => s.CurrentUserId);

        modelBuilder.Entity<DbUser>()
            .HasMany(s => s.Plots)
            .Withrequired(g => g.CurrentUser)
            .HasForeignKey(s => s.CurrentUserId);

        modelBuilder.Entity<DbPlot>()
            .HasOptional(x => x.Series)
            .WithOptionalDependent(s => s.ThermalPlot)
            .Map(x => x.MapKey("SeriesId"));

如您所见,Plots 表中的数据库中有 SeriesId 字段,但它没有在 C# 模型中表示。如何在 C# 模型中配置这种关系以具有实际的 SeriesId 属性。这个配置背后的主要思想是,DbPlot 总是属于某个用户,但它也可以指定,它属于某个系列,但它是可选的。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。