gpt4 book ai didi

java - 使用 JPA Criteria 构建器进行复杂查询

转载 作者:太空狗 更新时间:2023-10-29 22:43:07 25 4
gpt4 key购买 nike

有人可以建议我如何使用 JPA Criteria builder API 构建以下查询吗?

SELECT id,status,created_at from transactions where status='1' 
and currency='USD' and appId='123' order by id

如果我能找到一个基于给定参数动态创建的解决方案,那就更好了 Map<String,String>使用元模型类或任何其他方式。

最佳答案

是这样的(没有元模型):

Map<String, Object> params = ...;
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Tuple> cq = cb.createTupleQuery();
Root<Transaction> r = cq.from(Transaction.class);

Predicate p= cb.conjunction();
for (Map.Entry<String, Object> param: params.entrySet())
p = cb.and(p, cb.equal(r.get(param.getKey()), param.getValue()));

cq.multiselect(r.get("id"), r.get("status"), r.get("created_at"))
.where(p)
.orderBy(cb.asc(r.get("id")));

List<Tuple> result = em.createQuery(cq).getResultList();

或者使用元模型(类型安全,但有点冗长):

Map<SingularAttribute<Transaction, ?>, Object> params = ...;
CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Tuple> cq = cb.createTupleQuery();
Root<Transaction> r = cq.from(Transaction.class);

Predicate p= cb.conjunction();
for (Map.Entry<SingularAttribute<Transaction, ?>, Object> param: params.entrySet())
p = cb.and(p, cb.equal(r.get(param.getKey()), param.getValue()));

cq.multiselect(r.get(Transaction_.id), r.get(Transaction_.status),
r.get(Transaction_.created_at))
.where(p)
.orderBy(cb.asc(r.get(Transaction_.id)));

List<Tuple> result = em.createQuery(cq).getResultList();

关于java - 使用 JPA Criteria 构建器进行复杂查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3842122/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com