这是一个part表的条件查询,后端数据库是sqlserver,使用的是hibernate的orm框架,deleted字段是item表中的字段 part表和item表是外键关联的但是他们的关联很特殊 他们关联的字段是两个表的主键也就是说两个表公用一个主键 我现在要对以下这段代码进行修改要在这个条件查询中加入一个条件内容是item表的deleted字段为null 我应该怎么修改 public Page<Part> findByCriteria(PartCriteria criteria, Pageable page) { log.debug("find by criteria : {}, page: {}", criteria, page); final Specification<Part> specification = createSpecification(criteria); return partRepository.findAll(specification, page); }
时间: 2024-03-12 09:48:53 浏览: 63
可以在createSpecification方法中添加一个Predicate对象来表示item表的deleted字段为null的条件,如下所示:
```java
private Specification<Part> createSpecification(PartCriteria criteria) {
Specification<Part> specification = Specification.where(null);
if (criteria != null) {
if (criteria.getId() != null) {
specification = specification.and(buildSpecification(criteria.getId(), Part_.id));
}
if (criteria.getName() != null) {
specification = specification.and(buildStringSpecification(criteria.getName(), Part_.name));
}
// 添加item表的deleted字段为null的条件
Join<Part, Item> itemJoin = root.join(Part_.id, JoinType.LEFT).join(Item_.id, JoinType.LEFT);
specification = specification.and(itemJoin.get(Item_.deleted).isNull());
}
return specification;
}
```
这里使用了root.join方法来建立part表和item表之间的关联,使用了JoinType.LEFT表示使用左外连接。然后,使用and方法将新添加的条件与原有的条件进行逻辑与操作。最后,将修改后的Specification对象返回即可。
阅读全文