使用实体框架查询多对多关系

时间:2019-01-16 15:34:07

标签: c# entity-framework linq

我是C#实体框架的新手。我创建了三个班 -国家 -面积 -分区

国家和地区之间存在多对多关系。区域和分区之间还有另一对多的关系。

一个国家可以包含许多区域,但是也有属于多个国家的区域。区域和子区域相同。

我创建了各自的类,并且数据库表已自动创建。也已经创建了CountryAreas和SubAreaAreas的表,因此看起来都不错。另外,外键看起来还不错。

我能够通过(见下文)将数据写入表中。

我现在正在努力从数据库中选择所有具有相应区域和子区域的国家。

我读了几篇文章,似乎我缺乏有关LINQ查询和实体框架的基本知识。

public class Country
{
    #region attributes
    [Key]
    public string Name { get; set; }
    public List<Area> Areas { get; set; } // virtual enabled lazy loading
    #endregion
}

public class Area
{
    #region attributes
    [Key]
    public string Name { get; set; }
    public virtual List<SubArea> Subareas { get; set; }
    public virtual List<Country> Countries { get; set; }
    #endregion
}

public class SubArea
{
    #region attributes
    [Key]
    public string Name { get; set; }
    public virtual List<Area> Areas { get; set; }
    #endregion
}

public class LocationScoutContext : DbContext
{
    public LocationScoutContext()
        : base("name=LocationScout")
    {
    }

    public DbSet<Country> Countries { get; set; }
    public DbSet<Area> Areas { get; set; }
    public DbSet<SubArea> SubAreas { get; set; }

}


// *** reading the data works fine ***
using (var db = new LocationScoutContext())
{
   db.Countries.Add(newCountry);
   db.SaveChanges();
}


// *** I tried this ***
var allCountries = new List<Countries>();
using (var db = new LocationScoutContext())
{
   var query = from c in db.Countries select c;
}

foreach (var c in query)
{
   allCountries.Add(c);
}

我尝试了如上所示的操作,但这显然没有进行任何连接,只是给了我具有空区域和子区域的国家/地区名称。

感谢您的帮助:-)

1 个答案:

答案 0 :(得分:4)

尝试如下。这将为所有Comparator.comparingInt(String::length).reversed().thenComparing(Comparator.<String>naturalOrder())及其countriesareas

对于EF 6.x:

subareas

对于EF Core:

using (var db = new LocationScoutContext())
{
   var countries = db.Countries.Include(c => c.Areas.Select(a => a.SubAreas)).ToList();
}