3

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

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

有没有办法将 ICriteria 转换为 DetachedCriteria。我会接受有可信参考的“不”。

4

3 回答 3

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 中对其进行了最低限度的测试……不保证它会起作用或有任何用处。

于 2011-10-04T04:54:48.533 回答
2
var clonedDetachedCriteria = new ConvertedDetachedCriteria(CriteriaTransformer.Clone(criteria));

如果您的条件会话为 null ,则创建“对象引用..”异常。

采用CriteriaTransformer.Clone(criteria)

于 2011-10-12T10:05:30.570 回答
1

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

于 2010-07-28T12:45:31.517 回答