本文整理匯總了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();
}