本文整理了Java中javax.persistence.criteria.Predicate.getExpressions()
方法的一些代码示例,展示了Predicate.getExpressions()
的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。Predicate.getExpressions()
方法的具体详情如下:
包路径:javax.persistence.criteria.Predicate
类名称:Predicate
方法名:getExpressions
[英]Return the top-level conjuncts or disjuncts of the predicate. Returns empty list if there are no top-level conjuncts or disjuncts of the predicate. Modifications to the list do not affect the query.
[中]返回谓词的顶级连接或断开。如果谓词没有顶级连接或断开,则返回空列表。对列表的修改不会影响查询。
代码示例来源:origin: Impetus/Kundera
List<Expression<Boolean>> expressions = where.getExpressions();
for (Expression expr : expressions)
代码示例来源:origin: stackoverflow.com
private Specification<Event> buildSpecification(final EventFilter filter) {
final Specification<Event> specification = new Specification<Event>() {
@Override
public Predicate toPredicate(Root<Event> root, CriteriaQuery<?> cq, CriteriaBuilder cb) {
cq.distinct(true);
Predicate predicate = cb.conjunction();
if (filter.getEventGroupIds() != null) {
Join<Event, EventGroup> join = root.join(Event_.eventGroups);
predicate.getExpressions().add(join.get(EventGroup_.id).in(filter.getEventGroupIds()) );
}
return predicate;
}
};
return specification;
}
代码示例来源:origin: dhis2/dhis2-core
@Override
public int count( DeletedObjectQuery query )
{
CriteriaBuilder builder = getCurrentSession().getCriteriaBuilder();
CriteriaQuery<Long> criteriaQuery = builder.createQuery( Long.class );
Root<DeletedObject> root = criteriaQuery.from( DeletedObject.class );
Predicate predicate = buildCriteria( builder, root, query );
criteriaQuery.select( builder.countDistinct( root ) );
if ( !predicate.getExpressions().isEmpty() ) criteriaQuery.where( predicate );
Query<Long> typedQuery = getCurrentSession().createQuery( criteriaQuery );
return typedQuery.getSingleResult().intValue();
}
代码示例来源:origin: dhis2/dhis2-core
disjunction.getExpressions().add( root.get( "uid" ).in( query.getUid() ) );
disjunction.getExpressions().add( root.get( "code" ).in( query.getCode() ) );
if ( !disjunction.getExpressions().isEmpty() ) predicate.getExpressions().add( disjunction );
predicate.getExpressions().add( builder.or( root.get( "klass" ).in( query.getKlass() ),
root.get( "klass" ).in( query.getKlass() ) ) );
conjunction.getExpressions().add( root.get( "klass" ).in( query.getKlass() ) );
conjunction.getExpressions().add( root.get( "uid" ).in( query.getUid() ) );
disjunction.getExpressions().add( conjunction );
conjunction.getExpressions().add( root.get( "klass" ).in( query.getKlass() ) );
conjunction.getExpressions().add( root.get( "code" ).in( query.getUid() ) );
disjunction.getExpressions().add( conjunction );
if ( !disjunction.getExpressions().isEmpty() ) predicate.getExpressions().add( disjunction );
predicate.getExpressions().add( builder.greaterThanOrEqualTo( root.get( "deletedAt" ), query.getDeletedAt() ) );
代码示例来源:origin: stackoverflow.com
if(whereClause.getExpressions().isEmpty()) {
throw new RuntimeException("no criteria");
代码示例来源:origin: dhis2/dhis2-core
@Override
public List<DeletedObject> query( DeletedObjectQuery query )
{
CriteriaBuilder builder = getCurrentSession().getCriteriaBuilder();
CriteriaQuery<DeletedObject> criteriaQuery = builder.createQuery( DeletedObject.class );
Root<DeletedObject> root = criteriaQuery.from( DeletedObject.class );
Predicate predicate = buildCriteria( builder, root, query );
criteriaQuery.select( root );
if ( !predicate.getExpressions().isEmpty() ) criteriaQuery.where( predicate );
Query<DeletedObject> typedQuery = getCurrentSession().createQuery( criteriaQuery );
if ( !query.isSkipPaging() )
{
Pager pager = query.getPager();
typedQuery.setFirstResult( pager.getOffset() );
typedQuery.setMaxResults( pager.getPageSize() );
}
return typedQuery.list();
}
代码示例来源:origin: dhis2/dhis2-core
conjunction.getExpressions().add( predicate );
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
builder.or(builder.greaterThanOrEqualTo(root.<Date> get(expiryProperty.getName()), new Date()),
builder.isNull(root.<Date> get(expiryProperty.getName()))));
代码示例来源:origin: dhis2/dhis2-core
disjunction.getExpressions().add( root.get( "uid" ).in( query.getUid() ) );
disjunction.getExpressions().add( root.get( "code" ).in( query.getCode() ) );
disjunction.getExpressions().add( conjunction );
disjunction.getExpressions().add( conjunction );
代码示例来源:origin: com.github.dactiv/dactiv-orm
public Predicate build(PropertyFilter filter,SpecificationEntity entity) {
String matchValue = filter.getMatchValue();
Class<?> FieldType = filter.getFieldType();
MatchValue matchValueModel = getMatchValue(matchValue, FieldType);
Predicate predicate = null;
if (matchValueModel.hasOrOperate()) {
predicate = entity.getBuilder().disjunction();
} else {
predicate = entity.getBuilder().conjunction();
}
for (Object value : matchValueModel.getValues()) {
if (filter.hasMultiplePropertyNames()) {
for (String propertyName:filter.getPropertyNames()) {
predicate.getExpressions().add(build(propertyName, value, entity));
}
} else {
predicate.getExpressions().add(build(filter.getSinglePropertyName(), value, entity));
}
}
return predicate;
}
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
criteria.getBuilder().equal(fromProject.get(roleModelProperty.getName()), criteria.getRoot()));
conjunction.getExpressions().add(
criteria.getBuilder().equal(fromProject.get(memberModelProperty.getName()), store.lookupIdentityObjectById((IdentityType) object)));
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getMember())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(roleModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getRole())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(groupModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getGroup())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(groupModelProperty.getName()), store.lookupIdentityObjectById(new SimpleGroup(object.toString()))));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(roleModelProperty.getName()), store.lookupIdentityObjectById(new SimpleRole(object.toString()))));
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getMember())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(roleModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getRole())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(groupModelProperty.getName()), store.lookupIdentityObjectById(groupRole.getGroup())));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(groupModelProperty.getName()), store.lookupIdentityObjectById(new SimpleGroup(object.toString()))));
conjunction.getExpressions().add(
builder.equal(fromProject.get(memberModelProperty.getName()), root));
conjunction.getExpressions().add(
builder.equal(fromProject.get(roleModelProperty.getName()), store.lookupIdentityObjectById(new SimpleRole(object.toString()))));
代码示例来源:origin: FINRAOS/herd
@Test
public void testGetPredicateForInClauseTwoChunks()
{
// Create the JPA builder, query, and entity root.
CriteriaBuilder builder = entityManager.getCriteriaBuilder();
CriteriaQuery<BusinessObjectDataEntity> criteria = builder.createQuery(BusinessObjectDataEntity.class);
Root<BusinessObjectDataEntity> businessObjectDataEntity = criteria.from(BusinessObjectDataEntity.class);
// Get the predicate for the "in" clause with 1001 values (1 greater than the default chunking size).
Predicate predicate = baseJpaDaoImpl
.getPredicateForInClause(builder, businessObjectDataEntity.get(BusinessObjectDataEntity_.partitionValue), getPartitionValueList(1001));
// We expect to get back an "or" of 2 "in" expressions where each "in" expression is a list of chunked partition values.
assertEquals(Predicate.BooleanOperator.OR, predicate.getOperator());
List<Expression<Boolean>> expressions = predicate.getExpressions();
assertEquals(2, expressions.size());
// The first "in" clause will have the first 1000 elements and the second "in" clause will have the extra "1" element.
assertEquals(1000, ((InPredicate) expressions.get(0)).getValues().size());
assertEquals(1, ((InPredicate) expressions.get(1)).getValues().size());
}
代码示例来源:origin: com.github.dactiv/dactiv-orm
public Predicate build(PropertyFilter filter, SpecificationEntity entity) {
Object value = convertMatchValue(filter.getMatchValue(), filter.getFieldType());
Predicate predicate = null;
if (filter.hasMultiplePropertyNames()) {
Predicate orDisjunction = entity.getBuilder().disjunction();
for (String propertyName:filter.getPropertyNames()) {
orDisjunction.getExpressions().add(build(propertyName,value,entity));
}
predicate = orDisjunction;
} else {
predicate = build(filter.getSinglePropertyName(),value,entity);
}
return predicate;
}
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
criteria.getBuilder().equal(fromProject.get(groupModelProperty.getName()), criteria.getRoot()));
conjunction.getExpressions().add(
criteria.getBuilder().equal(fromProject.get(memberModelProperty.getName()), store.lookupIdentityObjectById((IdentityType) object)));
代码示例来源:origin: org.picketlink/picketlink-idm-impl
conjunction.getExpressions().add(
criteria.getBuilder().equal(fromProject.get(storeConfig.getModelProperty(PROPERTY_ATTRIBUTE_NAME).getName()),
customParameter.getName()));
conjunction.getExpressions().add(
(fromProject.get(storeConfig.getModelProperty(PROPERTY_ATTRIBUTE_VALUE).getName()).in((Object[]) parameterValues)));
内容来源于网络,如有侵权,请联系作者删除!