我有两张桌子:
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
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] 举报,一经查实,本站将立刻删除。