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; }
}
ありがとうございました。