本文整理汇总了Java中org.hibernate.criterion.DetachedCriteria.createCriteria方法的典型用法代码示例。如果您正苦于以下问题:Java DetachedCriteria.createCriteria方法的具体用法?Java DetachedCriteria.createCriteria怎么用?Java DetachedCriteria.createCriteria使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.hibernate.criterion.DetachedCriteria
的用法示例。
在下文中一共展示了DetachedCriteria.createCriteria方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: handleFindByInquiryValuesProbandSorted
import org.hibernate.criterion.DetachedCriteria; //导入方法依赖的package包/类
@Override
protected Collection<Trial> handleFindByInquiryValuesProbandSorted(Long departmentId, Long probandId, Boolean active, Boolean activeSignup) throws Exception {
org.hibernate.Criteria trialCriteria = createTrialCriteria("trial0");
if (departmentId != null) {
trialCriteria.add(Restrictions.eq("department.id", departmentId.longValue()));
}
org.hibernate.Criteria statusCriteria = trialCriteria.createCriteria("status", "trialStatus", CriteriaSpecification.INNER_JOIN);
DetachedCriteria valuesSubQuery = DetachedCriteria.forClass(InquiryValueImpl.class, "inquiryValue"); // IMPL!!!!
valuesSubQuery.setProjection(Projections.rowCount());
valuesSubQuery.add(Restrictions.eq("proband.id", probandId.longValue()));
// if (active != null || activeSignup != null) {
DetachedCriteria inquiriesSubQuery = valuesSubQuery.createCriteria("inquiry", "inquiry0", CriteriaSpecification.INNER_JOIN);
inquiriesSubQuery.add(Restrictions.eqProperty("trial.id", "trial0.id"));
if (active != null) {
inquiriesSubQuery.add(Restrictions.eq("active", active.booleanValue()));
}
if (activeSignup != null) {
inquiriesSubQuery.add(Restrictions.eq("activeSignup", activeSignup.booleanValue()));
}
inquiriesSubQuery = DetachedCriteria.forClass(InquiryImpl.class, "inquiry1"); // IMPL!!!!
inquiriesSubQuery.setProjection(Projections.rowCount());
inquiriesSubQuery.add(Restrictions.eqProperty("trial.id", "trial0.id"));
if (active != null) {
inquiriesSubQuery.add(Restrictions.eq("active", active.booleanValue()));
}
if (activeSignup != null) {
inquiriesSubQuery.add(Restrictions.eq("activeSignup", activeSignup.booleanValue()));
}
// }
trialCriteria.add(
Restrictions.or(
Subqueries.lt(0l, valuesSubQuery),
Restrictions.and(
Subqueries.lt(0l, inquiriesSubQuery),
Restrictions.and(
Restrictions.eq("trialStatus.inquiryValueInputEnabled", true),
Restrictions.eq("trialStatus.lockdown", false)
)
)
)
);
trialCriteria.addOrder(Order.asc("name"));
return trialCriteria.list();
}