java - 具有连接和动态参数的 JPA Criteria Builder
问题描述
我有 2 个具有一对多关系的课程。客户(类)有很多交易(类)
public class Customer {
@Id
private Long clientId;
private String name;
@OneToMany
private List<Transactions> transactions;
}
public class Transactions {
@JoinColumn(name = "clientId")
private Transactions transactions;
private int statusType;
private String amount;
}
int dynamicValue = 1003;
CriteriaQuery<Customer> criteriaQuery = getBuilder().createQuery(Customer.class);
Root<Customer> customersRoot = criteriaQuery.from(Customer.class);
Join<Customer, Transactions> transactions = customersRoot.join("transactions");
TypedQuery<Customer> query = em.createQuery(criteriaQuery.select(customerRoot).where(getBuilder().equal(transactions.get("statusType"), dynamicValue)));
List<Customer> customerList = (List<Customer>) query.getResultList();
我有 2 个来自数据库的数据: 客户表
ClientId | Name |
1 | James |
2 | Eli |
交易表:
ClientId | Status Type| Amount| TransactionId |
1 | 1002 | 100 | 1 |
1 | 1003 | 200 | 2 |
我需要在上面进行查询以接受多个参数(动态)。这些参数将来自客户的属性,例如名称,一些参数将来自 Transactions 类。但是,当我尝试执行上面的代码时,它总是在我的数据库中获得第一条记录(1002),这是不正确的。
请给我一点光。问题:
- 如何在标准构建器中实现多个动态参数?
- 我的查询有什么问题,为什么它总是获得第一条记录?
解决方案
你目前只是传递一个文字。这与参数不同。见http://www.datanucleus.org:15080/products/accessplatform_5_2/jpa/query.html#_criteria_api_parameters
将您的代码更改为
CriteriaQuery<Customer> criteriaQuery = getBuilder().createQuery(Customer.class);
Root<Customer> customersRoot = criteriaQuery.from(Customer.class);
Join<Customer, Transactions> transactions = customersRoot.join("transactions");
ParameterExpression param = getBuilder().parameter(int.class, "myParam");
TypedQuery<Customer> query = em.createQuery(criteriaQuery.select(customerRoot).where(getBuilder().equal(transactions.get("statusType"), param)));
// Execute with first parameter value
query.setParameter("myParam", 1003);
List<Customer> customerList = (List<Customer>) query.getResultList();
然后,如果结果有问题,请查看 JPA 提供程序日志中执行的 SQL,并且可以更好地理解问题
推荐阅读
- ios - UIAlertController 层次结构错误
- python-3.x - Python / MDAnalysis SelectionError:选择失败:'无法将字符串转换为浮点数
- python - 删除2级列表并将1级列表的元素组合成一个字符串
- node.js - 为什么 Babel 不转译我的 React 应用程序导入?
- php - Cakephp 3.6:两个表之间的多个外键
- php - Laravel:如何将值 api 数据传递给查看文件
- mysql - 为什么MySQL事务锁只阻塞其他锁?
- spring-mvc - hibernate spring mvc +jsp中的一对多映射
- java - HttpServletRequest 字段可能不是静态的、最终的或与球衣 2 有注释类型错误
- ajax - Angular HttpClient 流