我是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);
}
我尝试了如上所示的操作,但这显然没有进行任何连接,只是给了我具有空区域和子区域的国家/地区名称。
感谢您的帮助:-)
答案 0 :(得分:4)
尝试如下。这将为所有Comparator.comparingInt(String::length).reversed().thenComparing(Comparator.<String>naturalOrder())
及其countries
和areas
。
对于EF 6.x:
subareas
对于EF Core:
using (var db = new LocationScoutContext())
{
var countries = db.Countries.Include(c => c.Areas.Select(a => a.SubAreas)).ToList();
}