我正在使用 NHibernate 3.3.1 并发现了非常有趣的问题。
在我的域模型中,我定义了两个类:Carriage 和 CarriageRequest,它们相互引用。因为延迟加载打开,当我访问carriage.CarriageRequest - 它指向一个代理对象。好的,可以。但是当我调用 CarriageRequest 类中定义的任何方法时,“this”引用了第三个对象实例。

例子:

class CarriageRequest
{
  public virtual void Test(CarriageRequest instance)
  {
    Debug.WriteLine(Object.ReferenceEquals(this, instance)); // prints FALSE
  }
}

class Carriage
{
  public virtual CarriageRequest CarriageRequest { get; set; }
}

...
var carriage = session.Get<Carriage>(123);
carriage.CarriageRequest.Test(carriage.CarriageRequest);

所以看起来 NHibernate 代理包装原始对象并将所有方法调用转发到包装对象。在这种情况下如何使用“==”?
我需要做这样的事情:
var shipment = (from sh in Carriage.Shipments where sh.CarriageRequest == this & sh.Warehouse == waybill.Warehouse select sh).FirstOrDefault();

此代码在 代理对象内的 中执行,因此 'shipment' 始终为 null,因为 'sh.CarriageRequest == this' 始终为 false。因为 sh.CarriageRequest 是一个代理,而这是一个包装好的原始实例。

最佳答案

好的,NHibernate 保证同一 session 中加载对象的引用相等。如果使用延迟加载,它会使用代理包装真实对象,并且代理上的每个方法调用都会转发到包装的对象。因此,在这个对象中,'this' 和从 session 加载的同一个对象之间的每个引用比较都将失败(因为它将是一个不同的代理对象)。

因此,解决此问题的唯一方法是使用 Equals 方法或按主键进行比较。

关于c# - NHibernate、代理和平等,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19901778/

10-17 02:18