NHibernate:将ICriteria转换为DetachedCriteria

时间:2009-11-18 03:12:49

标签: nhibernate criteria icriteria detachedcriteria

任何人都知道如何将ICriteria转换为DetachedCriteria。我需要使用现有的ICriteria作为子查询的一部分,使用:

.Add(Subqueries.PropertyIn("Name", myDetachedCriteriaSubquery))

有没有办法将ICriteria转换为DetachedCriteria。我会接受'不',并提供可靠的参考资料。

3 个答案:

答案 0 :(得分:3)

继来自mattk的回答之后,您可以继承DetachedCriteria来访问其构造函数:

public class ConvertedDetachedCriteria : DetachedCriteria
{
    public ConvertedDetachedCriteria(ICriteria criteria) 
        : base((CriteriaImpl) criteria, criteria)
    {
        var impl = (CriteriaImpl) criteria;
        impl.Session = null;
    }
}

现在您可以编写如下代码:

var criteria = Session.CreateCriteria<Person>()
   .Add(Restrictions.Eq("Name", "John"));

var clonedDetachedCriteria = new ConvertedDetachedCriteria(criteria);

var newCriteria = Session.CreateCriteria<Person>()
    .SetProjection(Projections.SubQuery(clonedDetachedCriteria))
    .List<string>();

免责声明:我只对NH 2进行了最低限度的测试......不保证它可以使用或有任何用处。

答案 1 :(得分:2)

var clonedDetachedCriteria = new ConvertedDetachedCriteria(CriteriaTransformer.Clone(criteria));

如果您的条件会话为null,则创建“object referans ..”异常。

使用CriteriaTransformer.Clone(criteria)

答案 2 :(得分:1)

DetachedCriteria有一个构造函数,它接受ICriteria但它是内部的。它由CriteriaTransformer使用。也许你可以实现类似的东西?