首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用DTO集合NHibernate查询DTO

使用DTO集合NHibernate查询DTO
EN

Stack Overflow用户
提问于 2012-06-05 20:49:22
回答 1查看 339关注 0票数 1

我有ObjectA (有相应的ObjectADTO)和ObjectB的集合(有相应的ObjectBDTO)。如何在ObjectB上查询所有带有join的ObjectA并将它们都映射到DTO中?我真的不想从db查询所有的东西。

代码语言:javascript
复制
    class ObjectA {
        public string Name { get; set; }
        public byte[] Garbage { get; set; }
        public IEnumerable<ObjectB> Collection { get; set; }
    }

    class ObjectB {
        public string Name { get; set; }
        public byte[] Garbage { get; set; }
        public ObjectA Parent { get; set; }
    }

//映射到=>

代码语言:javascript
复制
    class ObjectADTO {
        public string Name { get; set; }
        public IEnumerable<ObjectBDTO> Collection { get; set; }
    }

    class ObjectBDTO {
        public string Name { get; set; }
        public ObjectADTO Parent { get; set; }
    }
EN

回答 1

Stack Overflow用户

发布于 2012-06-06 14:29:26

可以做这样的事情:

代码语言:javascript
复制
ObjectB objectBAlias = null;
var query = _session.QueryOver<ObjectA>()
.JoinAlias(x=>x.Collection, ()=> objectBAlias, JoinType.LeftOuterJoin)
.List();

var list = query.Select(x=>new ObjectADTO
{
   Name=x.Name,
   Children=x.Collection.Select(c=>new ObjectBDTO {Name=c.Name, Parent=x).ToList()
})
.ToList();

我没有检查VS中的语法,但是您已经明白了

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10897613

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档