Я думаю, что вам может понадобиться сделать MutiQuery и собрать вместе родителей и детей DTO.

ьзуя NHibernate 2.1, я пытаюсь спроецировать сущность и ее дочернюю коллекцию в DTO. Моя сущность выглядит так ...

public class Application
{
  public int Id {get;set;}
  public string Name {get;set;}
  public List<ApplicationSetting> Settings {get;set;}
  // A bunch of other properties that I don't want in the DTO
}

public class ApplicationSetting
{
   public int Id {get;set;}
   public string Name {get;set;}
   public string Code {get;set;}
   // A bunch of other properties that I don't want in the DTO
}

Мой DTO выглядит так ..

public ApplicationDto
{
      public int Id {get;set;}
      public string Name {get;set;}
      public List<ApplicationSettingDto> Settings {get;set;}
}

public class ApplicationSettingDto
{
   public int Id {get;set;}
   public string Name {get;set;}
   public string Code {get;set;}
}

Мой код, чтобы выбрать просто приложение и спроектировать именно это (используя Nhibernate 2.1 и nhLambdaExtensions)

  var applicationAlias = new Application();

  var criteria = Session
    .Add<Application>(a => a.Id == id);

      int? Id = null;
  string Name = null;

  criteria
    .SetProjection
    (
      Projections.Distinct(
        Projections.ProjectionList()
          .Add(LambdaProjection.Property<Application>(a => a.Id).As(() => Id))
          .Add(LambdaProjection.Property<Application>(a => a.Name).As(() => Name))
        )
    );

  criteria.SetResultTransformer(Transformers.AliasToBean(typeof(ApplicationDto)));

  var contract = criteria.UniqueResult<ApplicationDto>();

Мой вопрос: как мне проецировать НЕКОТОРЫЕ свойства из сущности ApplicationSettings в дочернюю коллекцию ApplicationSettingsDto?

Ответы на вопрос(1)

Ваш ответ на вопрос