Entity Framework管理一对二实体关系

 更新时间:2022年03月05日 09:37:18   作者:.NET开发菜鸟  
本文详细讲解了Entity Framework管理一对二实体关系的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

上一篇文章中,简单的介绍了使用Fluent API如何管理一对一的实体关系,在这篇文章中,接着介绍Fluent API如何管理一对多的实体关系。

要在数据库中配置一对多关系,我们可以依赖EF约定,还可以使用数据注解或Fluent API来显式创建关系。接下来使用捐赠者Donator和支付方法PayWay这两个类来举例子,这里的一对多关系是:一个人可以通过多种支付方式赞助我。

支付方式类PayWay结构如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OneToMany.Model.Model
{
    public class PayWay
    {
        public int PayWayId { get; set; }

        public string Name { get; set; }

        public virtual Donator Donator { get; set; }
    }
}

因为一个赞助者可以通过多种支付方式赞助我,这句话就表明了Donator对象应该有一个PayWay的集合,因此,我们要给Donator类新加入一个集合属性,捐赠者类Donator结构如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OneToMany.Model.Model
{
    public class Donator
    {
        public int Id { get; set; }

        public string Name { get; set; }

        public string Amount { get; set; }

        public DateTime DonateDate { get; set; }

        /// <summary>
        /// PayWay类型的集合属性
        /// </summary>
        public virtual ICollection<PayWay> PayWays { get; set; }
    }
}

Donator类的配置伙伴类的定义如下:

using OneToMany.Model.Model;
using System;
using System.Collections.Generic;
using System.Data.Entity.ModelConfiguration;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OneToMany.Map.Map
{
    public class DonatorMap :EntityTypeConfiguration<Donator>
    {
        public DonatorMap()
        {
            ToTable("Donator");
            //将Name设置为必须
            this.Property(p => p.Name).IsRequired();
        }

    }
}

PayWay的配置伙伴类的定义如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using OneToMany.Model.Model;
using System.Data.Entity.ModelConfiguration;

namespace OneToMany.Map.Map
{
    public class PayWayMap : EntityTypeConfiguration<PayWay>
    {
        public PayWayMap()
        {
            ToTable("PayWay");
            this.Property(p => p.Name).HasMaxLength(16);
        }
    }
}

EFDbContext类定义如下:

using OneToMany.Model.Model;
using System;
using System.Collections.Generic;
using System.Data.Entity;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OneToMany.Map.EFContext
{
    public class EFDbContext:DbContext
    {
        public EFDbContext()
            : base("name=CodeFirstApplication")
        { }

        public DbSet<PayWay> PayWays { get; set; }
        public DbSet<Donator> Donators { get; set; }


        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            // 设置主键
            modelBuilder.Entity<PayWay>().HasKey(p => p.PayWayId);
            modelBuilder.Entity<Donator>().HasKey(p => p.DonatorId);
            // 设置一对多
            modelBuilder.Entity<Donator>().HasMany(p => p.PayWays).WithRequired(t => t.Donator);
            base.OnModelCreating(modelBuilder);
        }
    }
}

控制台程序定义如下:

using OneToMany.Map.EFContext;
using OneToMany.Model.Model;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace OneToManyApplication
{
    class Program
    {
        static void Main(string[] args)
        {
            using (var context = new EFDbContext())
            {
                var donator = new Donator
                {
                    Amount = 6,
                    Name = "虾米",
                    DonateDate = DateTime.Now,
                    PayWays = new List<PayWay> {
                      new PayWay{Name="支付宝"},
                      new PayWay{Name="微信"}

                    }
                };
                context.Donators.Add(donator);
                context.SaveChanges();
            }

            Console.WriteLine("执行成功");
            Console.ReadKey();
        }
    }
}

程序运行后数据库结构如下:

查询数据:

到此这篇关于Entity Framework管理一对二实体关系的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • ASP.net全局程序文件Global.asax用法分析

    ASP.net全局程序文件Global.asax用法分析

    这篇文章主要介绍了ASP.net全局程序文件Global.asax用法,较为详细分析了Global.asax文件中几个常见选项的含义及用法,需要的朋友可以参考下
    2014-10-10
  • ASP.NET MVC Layout如何嵌套

    ASP.NET MVC Layout如何嵌套

    这篇文章主要为大家详细介绍了ASP.NET MVC Layout如何嵌套,ASP.NET MVC Layout进行嵌套的方法,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • 浅谈c#设计模式之单一原则

    浅谈c#设计模式之单一原则

    这篇文章主要介绍了浅谈.net设计模式之单一原则,需要的朋友可以参考下
    2014-12-12
  • 如何利用IIS调试ASP.NET网站程序详解

    如何利用IIS调试ASP.NET网站程序详解

    这篇文章主要给大家介绍了关于如何利用IIS调试ASP.NET网站程序的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01
  • ASP.NET中弹出消息框的几种常见方法

    ASP.NET中弹出消息框的几种常见方法

    这篇文章主要介绍了ASP.NET中弹出消息框的几种常见方法,给出了几种常见的弹出消息框的方法,并总结对比了几种方法的特点,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-11-11
  • ASP.NET数组删除重复值实现代码

    ASP.NET数组删除重复值实现代码

    在ASP.NET编程中,要想删除数组的重复值可以使用多种方法代码实现相同的效果。今天,在某个博客中看到某功能代码中的一小段代码很不错,它就是用来移动数组中相同值的方法,分享给大家
    2015-10-10
  • .NET Core配置连接字符串和获取数据库上下文实例

    .NET Core配置连接字符串和获取数据库上下文实例

    这篇文章介绍了.NET Core配置连接字符串和获取数据库上下文实例的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-01-01
  • 如何判断 .NET Core 应用程序以管理员身份运行的

    如何判断 .NET Core 应用程序以管理员身份运行的

    这篇文章主要介绍了如何判断 .NET Core 应用程序是以管理员身份运行的,我们需要知道当前程序是否以管理员身份运行,以便执行一些需要特殊权限的操作,下面为我们就来学习具体的方法吧,需要的朋友可以参考一下
    2022-03-03
  • 阿里大鱼简单发送短信功能.net core版

    阿里大鱼简单发送短信功能.net core版

    这篇文章主要介绍了阿里大鱼发送短信功能.net core版,.net core版实现,只是简单发送短信功能,供大家参考,感兴趣的小伙伴们可以参考一下
    2016-07-07
  • .NET Core跨平台资源监控工具CZGL.SystemInfo用法

    .NET Core跨平台资源监控工具CZGL.SystemInfo用法

    这篇文章介绍了.NET Core跨平台资源监控工具CZGL.SystemInfo的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02

最新评论