域对象如何包含从其他数据库映射属性计算值的属性,以便nhibernate.linq可以在域对象实例和数据库级别中使用计算属性。
我希望能够在直接使用对象时使用该属性:
Console.WriteLine(Entity.Calculated.ToString());
使用nhibernate.linq时
var q = from e in session.Linq<Entity>()
where e.Calculated > 0
select e;
答案 0 :(得分:3)
您需要复制类和映射中的逻辑。这是一个例子:
类别:
public class Invoice
{
public virtual int Id { get; protected set; }
public virtual decimal Amount { get; set; }
public virtual decimal Paid { get; set; }
public virtual decimal Balance
{
get { return Amount - Paid; }
}
}
映射:
<class name="Invoice">
<id name="Id">
<generator class="hilo"/>
</id>
<property name="Amount"/>
<property name="Paid"/>
<property name="Balance" formula="Amount - Paid" access="readonly"/>
</class>
现在您可以在Invoice.Balance