2

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 子コレクションに投影するにはどうすればよいですか?

4

1 に答える 1

3

MutiQuery を実行して、DTO の親と子を自分でまとめる必要があると思います。

于 2011-05-29T02:58:41.553 に答える