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

c# – 如何使用Linq选择具有一对多关系的所有内容

我有两张桌子:

CREATE TABLE Thing (
    Id int,Name nvarchar(max)
);

CREATE TABLE SubThing (
        Id int,Name nvarchar(max),ThingId int (foreign key)
    );

我想选择所有具有SubThings列表的东西并将它们设置为Thingviewmodel.

Thing viewmodel很简单:

public class Thingviewmodel
{
    public int Id { get; set; }
    public string Name { get; set; }
    public List<SubThingviewmodel> SubThings { get; set; }
}

SubThingviewmodel是:

public class SubThingviewmodel
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }

我已经选择了像这样的Thing记录:

List<Thingviewmodel> things = null;
things = _context.Things.OrderBy(b => b.Name)
    .Select(b => new Thingviewmodel
    {
         Id = b.Id,Name = b.Name
    }).ToList();

如何将SubThings添加查询viewmodel?

解决方法

您可以使用SubThings navigation property进行另一次投影:

things = _context.Things.OrderBy(b => b.Name)
.Select(b => new Thingviewmodel
{
     Id = b.Id,Name = b.Name,SubThings =b.SunThings.Select(st=>new SubThingviewmodel{Id =st.Id,...}).ToList()
}).ToList();

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

相关推荐