任何人都知道如何将ICriteria转换为DetachedCriteria。我需要使用现有的ICriteria作为子查询的一部分,使用:
.Add(Subqueries.PropertyIn("Name", myDetachedCriteriaSubquery))有没有什么方法可以把ICriteria转换成DetachedCriteria。我会接受一个可信的推荐人说“不”。
发布于 2011-10-04 12:54:49
根据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>();免责声明:我只在NH2中进行了最低限度的测试...不能保证它会工作,也不会有任何用处。
发布于 2011-10-12 18:05:31
var clonedDetachedCriteria = new ConvertedDetachedCriteria(CriteriaTransformer.Clone(criteria));如果您的条件会话为空,请创建“对象引用..”异常。
使用CriteriaTransformer.Clone(criteria)
发布于 2010-07-28 20:45:32
DetachedCriteria有一个接受ICriteria的构造函数,但它是内部的。它由CriteriaTransformer使用。也许你可以实现一些类似的东西?
https://stackoverflow.com/questions/1753408
复制相似问题