How to use CriteriaQuery SUM of custom operation on some cells?

泄露秘密 提交于 2019-12-19 04:04:26

问题


Consider you have table T, with fields A and B.

With regular SQL, I could do this:

SELECT SUM(A * (100.0 - B) / 100.0) AS D FROM T;

And I would get exactly what I expect.

However, I'm not sure how to do it with CriteriaQuery.

I know how to do sum over 1 field, but not how to do sum over some math expression over multiple fields in a row.


回答1:


The CriteriaBuilder interface provides the following arithmetic functions:

  • addition: sum(a, b)
  • substraction: diff(a, b)
  • multiplication: prod(a, b)
  • division: quot(a, b)

where a b parameters can be an expression and/or literal.

As for the query, here is an exampe written in a human readable form:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Number> q = cb.createQuery(Number.class);
Root<T> t = q.from(T.class);

// build SUM(A * (100.0 - B) / 100.0) expression
Expression<Double> diff = cb.diff(100.0, t.<Double>get("B"));
Expression<Double> prod = cb.prod(t.<Double>get("A"), diff);
Expression<Number> quot = cb.quot(prod, 100.0);
Expression<Number> sum = cb.sum(quot);
q.select(sum.alias("D"));

System.out.println(em.createQuery(q).getSingleResult());

You can also build the query as an one-liner:

q.select(cb.sum(cb.quot(cb.prod(t.<Double>get("A"), cb.diff(100.0, t.<Double>get("B"))), 100.0)).alias("D"));

I hope it clarifies your doubts.



来源:https://stackoverflow.com/questions/21627704/how-to-use-criteriaquery-sum-of-custom-operation-on-some-cells

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!