开发者

How do I get the entity type on an object that may be a NHibernate proxy object?

I have a base class DomainObject for all my business objects I am using with NHibernate. It contains the Id property.

public abstract class DomainObject
{
    public virtual int Id { get; private set; }
}

I would like to write an IEqualityComparer to compare my domain objects. If two objects have the same Id and are the same kind of object they should be equal. However when I use GetType() to get the type of the object, it will return the NHibernate proxy type. So this code:

bool IEqualityComparer.Equals(object x, object y)
{
    // null checking code skipped here
    if(x is DomainObject && y is DomainObject)
    {
            return ((DomainObject) x).Id == ((DomainObject) y).Id
                    && x.GetType() == y.GetType();
    }
    return x.Equals(y);
}

Doesn't work correctly, because the type of x is Asset but the type of y is AssetProxy218开发者_StackOverflow中文版79bba3e9e47edbbdc2a546445c657.

So, how do I get the entity type on an object that may be a NHibernate proxy object? i.e. in the example above Asset instead of AssetProxy21879bba3e9e47edbbdc2a546445c657?


You can get the real type of a proxy with:

NHibernateUtil.GetClass(x);

or you can add a method to DomainObject like:

public virtual Type GetTypeUnproxied()
{
    return GetType();
}

Which is really slick and doesn't depend directly on NHibernate.

Alternatively, one can approach the problem by saying you need to get the true object, rather than the proxy, which, if the session is handy, can be done with:

session.PersistenceContext.Unproxy(x);

As mentioned in another answer, if you're trying to implement equals it would be a good idea to check out the Sharp architecture implementation of Equals.


To get real object instead of proxy you can use

session.PersistenceContext.Unproxy(proxyObject)

But I think you should look at Sharp architecture implementation for Equals.


You can implement a backdoor property as described here to get the actual nonproxied instance.


i took a different aproach in a production project. I simply have a global HiLow Id-Generator which generates Id's unique for all types then i can:

// in DomainEntity
public override bool Equals(object obj)
{
    var other = obj as DomainEntity;
    if (Id == 0) // IsTransient()
        return ReferenceEquals(this, other);
    else
        return (other != null) && (Id == other.Id);
}

// Comparer
bool IEqualityComparer.Equals(object x, object y)
{
    return object.Equals(x, y);
}
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜