У меня есть две таблицы в базе данных MySQL.
- товар
- order_item
Клиенты размещают заказы на продукты, которые хранятся в таблице order_item
— отношение «один ко многим» от product
до order_item
.
В настоящее время я выполняю следующий запрос.
SELECT t0.prod_id,
sum(t1.quantity_ordered)
FROM projectdb.product t0,
projectdb.order_item t1
WHERE (t0.prod_id = t1.prod_id)
GROUP BY t0.prod_id
HAVING (sum(t1.quantity_ordered) >= ?)
ORDER BY sum(t1.quantity_ordered) DESC
Критерий запроса, который создает этот SQL, выглядит следующим образом.
CriteriaBuilder criteriaBuilder=entityManager.getCriteriaBuilder();
CriteriaQuery<Object[]>criteriaQuery=criteriaBuilder.createQuery(Object[].class);
Metamodel metamodel = entityManager.getMetamodel();
Root<OrderItem> root = criteriaQuery.from(metamodel.entity(OrderItem.class));
Join<OrderItem, Product> orderItemProdJoin = root.join(OrderItem_.prodId, JoinType.INNER);
List<Expression<?>>expressions=new ArrayList<Expression<?>>();
expressions.add(orderItemProdJoin.get(Product_.prodId));
expressions.add(criteriaBuilder.sum(root.get(OrderItem_.quantityOrdered)));
criteriaQuery.multiselect(expressions.toArray(new Expression[0]));
criteriaQuery.groupBy(orderItemProdJoin.get(Product_.prodId));
criteriaQuery.having(criteriaBuilder.greaterThanOrEqualTo(criteriaBuilder.sum(root.get(OrderItem_.quantityOrdered)), criteriaBuilder.literal(5)));
criteriaQuery.orderBy(criteriaBuilder.desc(criteriaBuilder.sum(root.get(OrderItem_.quantityOrdered))));
List<Object[]> list = entityManager.createQuery(criteriaQuery).getResultList();
Этот запрос суммирует количество каждой группы продуктов в таблице order_item
.
Он отображает список строк, который выглядит следующим образом.
prod_id qunatity_ordered
6 11
8 8
26 8
7 7
31 7
12 6
27 6
24 5
9 5
Можно ли просто подсчитать количество строк, созданных этим запросом - в данном случае 9?
Я использую JPA 2.1, предоставленный EclipseLink 2.5.2 и Hibernate 4.3.6 final.