Nhibernate проекция с детской коллекцией - PullRequest
2 голосов
/ 27 мая 2011

Используя 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 Ответ

3 голосов
/ 29 мая 2011

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

...