0

我的 DTO:

public class ServiceWithCount
{
  public Service Service { get; set; }
  public long Count { get; set; }
}

和:

public class Service
{
  public virtual long Id { get; set; }
  ...
}
public class Vote
{
  public virtual long Id { get; set; }
  public virtual Service Service { get; set; }
  ...
}

我想做类似的事情:

ServiceWithCount dto = null;
Service serviceAlias = null;

var result = session.QueryOver<Service>(() => serviceAlias)
  .Where(x => x.Serie.Id == serie.Id)
  .SelectList(list =>
    list
      .SelectSubQuery(QueryOver.Of<Vote>().Where(y => y.Service.Id == serviceAlias.Id).ToRowCountInt64Query()).WithAlias(() => dto.Count)
      .Select(x => x).WithAlias(() => dto.Service) //This line causes error
  )
  .TransformUsing(Transformers.AliasToBean<ServiceWithCount>())
  .List<ServiceWithCount>();

但这会导致错误:

could not resolve property:  of: MyNamespace.Service

如何将根类型对象作为 dto 的组件返回?

4

1 回答 1

0

使用 Linq 的解决方案:

添加命名空间:

using System.Linq;
using NHibernate;
using NHibernate.Linq;

并查询如下内容:

var result = (from s in session.Query<Service>()
             where s.Serie.Id == serie.Id
             let count = session.Query<Vote>().Count(v => v.Service.Id == s.Id)
             select new ServiceWithCount() { Service = s, Count = count })
             .ToList();

我认为Service在 DTO 中公开你的实体不是一个好习惯,你可以公开简单的属性只是为了获取你想要传输的信息,避免从 DTO 内部的 nhibernate 获取代理的风险。

于 2014-04-10T11:45:35.867 回答