2012-04-25 17 views
0

を返す:は2つのエンティティに参加し、私はそのようなマスター・エンティティTrnx持つ別のエンティティ

public class MasterTrnx 
{ 
    private int? _AccountId; 
    private string _Place; 
    private DateTime _ProcessTime; 
    private int _TrnxId; 
    private decimal? _PaymentValue; 
    } 

を、マスターのような子エンティティ:

public class MasterTrnxDetail 
    { 
    private MasterTrnx _MasterTrnx; 
    private decimal _MasterPaymentValue; 
    private decimal _PaymentValue; 
    private int _Xid; 
    } 

一つMasterTrnxエンティティがMasterTrnxDetailより1つを持っています子。

using (ISession session = base.GetSession()) 
     { 
      try 
      { 
       tx = session.BeginTransaction(); 

       listOfMasterTrnxDetail = session.QueryOver<MasterTrnxDetail>() 
        .JoinQueryOver(d => (IEnumerable<MasterTrnx>)d.Trnx) 
        .List(); 

       tx.Commit(); 
      } 
      catch (Exception e) 
      { 
       if (tx != null) 
       { 
        tx.Rollback(); 
       } 
       throw e; 
      } 
      finally 
      { 
       session.Close(); 
      } 

      return listOfMasterTrnxDetail; 
     } 

このコードブロックは機能しています。たとえば、私はマスターエンティティを持っていて、それには3つのmasterdetailがあります。このコードは私に3レコードを与えます。しかし、私は1つのマスターレコードと詳細の合計MasterPaymentValuesが必要です。どうやってやるの?また、このメソッドは、そのような別のエンティティを返します:

public class Trnx 
{ 
    public decimal? PaymentValue { get; set; } 
    public DateTime ProcessTime { get; set; } 
    public string TrnxName { get; set; } 
    public decimal? TotalMasterPaymentValue { get; set; } 
} 

ありがとうございました。

答えて

0

あなたのクラスモデルは少し奇妙に思えるので、私は唯一の

MasterTrnx mastertx = null; 

var subquery = QueryOver.Of<MasterTrnxDetail>() 
    .Where(detail => detail.MasterTrnx = mastertx) 
    .Select(Projections.Sum<MasterTrnxDetail>(d => d.PaymentValue)); 


Trnx dto = null; 

transactions = session.QueryOver(() => mastertx) 
    .SelectList(list => list 
     .Select(t => t.ProcessTime).WithAlias(() => dto.ProcessTime) 
     .Select(t => t.Place).WithAlias(() => dto.TrnxName) 
     .Select(Projections.Subquery(subquery)).WithAlias(() => dto.TotalMasterPaymentValue) 
    ) 
    .TransformUsing(Transformers.AliasToBean<Trnx>()) 
    .List<Trnx>(); 
を推測することができます
関連する問題