任何人都知道如何将 ICriteria 转换为 DetachedCriteria。我需要使用现有的 ICriteria 作为子查询的一部分,使用:
.Add(Subqueries.PropertyIn("Name", myDetachedCriteriaSubquery))
有没有办法将 ICriteria 转换为 DetachedCriteria。如果有可靠的参考资料,我会接受“不”。
根据 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 中对此进行了最低限度的测试...不保证它会起作用或有任何用处。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)