当前位置: 首页>>代码示例>>Java>>正文


Java CriteriaQuery.multiselect方法代码示例

本文整理汇总了Java中javax.persistence.criteria.CriteriaQuery.multiselect方法的典型用法代码示例。如果您正苦于以下问题:Java CriteriaQuery.multiselect方法的具体用法?Java CriteriaQuery.multiselect怎么用?Java CriteriaQuery.multiselect使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在javax.persistence.criteria.CriteriaQuery的用法示例。


在下文中一共展示了CriteriaQuery.multiselect方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: search

import javax.persistence.criteria.CriteriaQuery; //导入方法依赖的package包/类
@Override
public Optional<SearchResponse> search(final ServiceUser user,
                                       final SearchRequest request){
    final String dataSourceUuid = request.getQuery().getDataSource().getUuid();

    try (final Session session = database.openSession()) {
        final CriteriaBuilder cb = session.getCriteriaBuilder();

        final CriteriaQuery<Tuple> cq = cb.createTupleQuery();
        final Root<T> root = cq.from(this.dtoClass);

        cq.multiselect(this.fields.stream()
                .map(f -> root.get(f.getName()))
                .collect(Collectors.toList()));

        final Predicate requestPredicate = getPredicate(cb, root, request.getQuery().getExpression());
        final Predicate dataSourcePredicate = cb.equal(root.get(QueryableEntity.DATA_SOURCE_UUID), dataSourceUuid);

        cq.where(cb.and(requestPredicate, dataSourcePredicate));
        final List<Tuple> tuples = session.createQuery(cq).getResultList();
        final SearchResponse searchResponse = projectResults(request, tuples);

        return Optional.of(searchResponse);
    }
}
 
开发者ID:gchq,项目名称:stroom-query,代码行数:26,代码来源:QueryServiceCriteriaImpl.java

示例2: aggregate

import javax.persistence.criteria.CriteriaQuery; //导入方法依赖的package包/类
private <S> S aggregate(CriteriaBuilder builder, CriteriaQuery<S> query, Root<E> root, Specification<E> spec, List<Selection<?>> selectionList, LockModeType lockMode) {
	if (selectionList != null) {
		Predicate predicate = spec.toPredicate(root, query, builder);
		if (predicate != null) {
			query.where(predicate);
		}
		query.multiselect(selectionList);
		return (S) em.createQuery(query).setLockMode(lockMode).getSingleResult();
	}
	return null;
}
 
开发者ID:onsoul,项目名称:os,代码行数:12,代码来源:GenericRepositoryImpl.java

示例3: findAllImpl2

import javax.persistence.criteria.CriteriaQuery; //导入方法依赖的package包/类
private <R> List<R> findAllImpl2(final DatatableQuery<R, T> input, final Specifications<T> specifications,
      final Pageable pageable) {
      
      // create query
  	final EntityManager entityManager = entityManagerFactory.createEntityManager();
      final CriteriaBuilder qb = entityManager.getCriteriaBuilder();        
      final CriteriaQuery<R> cq = qb.createQuery(input.getQueryClass());

      // Etablir entité racine
      final Root<T> from = cq.from(this.entity);
      
      // select for custom class
      final List<Selection<?>> selectList = new ArrayList<Selection<?>>();
      if (input.getGroupByColumns() != null) {
          DatatableHelper.getExpressions(from, input.getGroupByColumns(), selectList);
      } else {
          DatatableHelper.getExpressions(from, input.getColumns(), selectList);
      }
      cq.multiselect(selectList);

      // where
      if (specifications != null) {
          cq.where(specifications.toPredicate(from, cq, qb));
      }

      // group by
      if (input.getGroupByColumns() != null && !input.getGroupByColumns().isEmpty()) {
          final List<Expression<?>> groupByList = new ArrayList<Expression<?>>();
          DatatableHelper.getExpressions(from, input.getGroupByColumns(), groupByList);
          cq.groupBy(groupByList);
      }

      // order by
      if (pageable != null && pageable.getSort() != null) {
          cq.orderBy(DatatableHelper.getOrderBy(from, qb, pageable));
      }

      // page limit
      final TypedQuery<R> q = entityManager.createQuery(cq);
      if (pageable != null) {
      	LOGGER.log(Level.FINE, "Pageable: offset: {0}, page size: {1}", new Object[]{pageable.getOffset(), pageable.getPageSize()});
          q.setFirstResult(pageable.getOffset());
          q.setMaxResults(pageable.getPageSize());
      }

      // execute query
      final List<R> ret = q.getResultList();
      entityManager.close();
return ret;
  }
 
开发者ID:andresoviedo,项目名称:datatable-java,代码行数:51,代码来源:DatatableDAOImpl.java


注:本文中的javax.persistence.criteria.CriteriaQuery.multiselect方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。