嗨,伙计们,我试图从多个表拉数据在一个SQL查询使用LINQ和实体框架.我需要从数据库中获得的细节。
我已经参考了这个 如何在C#中过滤JSON数组我无法实现这一点,希望得到任何人的帮助。
public partial class Regions
{
public Regions()
{
Projects = new HashSet<Projects>();
RegionUserRelation = new HashSet<RegionUserRelation>();
}
public int RegionId { get; set; }
[Required]
public string RegionName { get; set; }
[Required]
public string RegionFullname { get; set; }
[Required]
public int RegionTypeId { get; set; }
public string RegionMisc { get; set; }
public RegionType RegionType { get; set; }
public ICollection<Projects> Projects { get; set; }
public ICollection<RegionUserRelation> RegionUserRelation { get; set; }
}
public partial class Projects
{
public Projects()
{
Sections = new HashSet<Sections>();
}
public Guid ProjectId { get; set; }
[Required]
public string ProjectName { get; set; }
[Required]
public string ProjectCode { get; set; }
public string ProjectDesc { get; set; }
[Required]
public int RegionId { get; set; }
[Required]
public int EpsgId { get; set; }
public Epsg Epsg { get; set; }
public Regions Region { get; set; }
public ICollection<Sections> Sections { get; set; }
}
public partial class Sections
{
public Sections()
{
Flights = new HashSet<Flights>();
}
public Guid SectionId { get; set; }
[Required]
public string SectionName { get; set; }
public string SectionDesc { get; set; }
[Required]
public Guid ProjectId { get; set; }
public Projects Project { get; set; }
public ICollection<Flights> Flights { get; set; }
}
预期的输出是像
{ "Regions" :
[ {
"region_id" : "2012",
"region_name" : "region1",
"region_fullname" : "21700",
"region_type" : "MERCH",
"Projects" : [
{ "project_id" : 2341,
"project_name " : "DXY",
"project_code " : "21700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
"Projects" : [
{ "project_id" : 1321,
"project_name " : "Proj_2",
"project_code " : "01700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
]
},
{
"region_id" : "2013",
"region_name" : "region3",
"region_fullname" : "21330",
"region_type" : "MERCH",
"Projects" : [
{ "project_id" : 2341,
"project_name " : "DXY",
"project_code " : "21700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
"Projects" : [
{ "project_id" : 1321,
"project_name " : "Proj_2",
"project_code " : "01700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
]
},
{
"region_id" : "2012",
"region_name" : "region2",
"region_fullname" : "24300",
"region_type" : "MERCH",
"Projects" : [
{ "project_id" : 2341,
"project_name " : "DXY",
"project_code " : "21700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
"Projects" : [
{ "project_id" : 1321,
"project_name " : "Proj_2",
"project_code " : "01700",
"sections" : [
{ "section_id" : 4356,
"section_name" : sec_name,
"section_description" : sec_dis},
{ "section_id" : 476,
"section_name" : sec_name2,
"section_description" : sec_dis2},
{ "section_id" : 908,
"section_name" : sec_name3,
"section_description" : sec_dis3}
]
},
]
},
] }
由你的评论规范:使用 Include
然后 ThenInclude
. 你的模型中有导航属性,所以你可以利用它的优势--参考链接--。https:/docs.microsoft.comen-usefcorequeryingrelated-data。
using (var context = new YourContex())
{
var regions = context.Regions
.Include(blog => blog.Projects)
.ThenInclude(post => post.Sections)
.ToList()
.Select(region => new YourDTO(){}); //you need to specify this by your expectation or just omit it and keep original model
}