这是一个part表的条件查询,后端数据库是sqlserver,使用的是hibernate的orm框架,deleted字段是item表中的字段 part表和item表是外键关联的但是他们的关联很特殊 他们关联的字段是两个表的主键也就是说两个表公用一个主键 我现在要对以下这段代码进行修改要在 criteria中加入一个条件内容是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); }这是一个part表的条件查询,后端数据库是sqlserver,使用的是hibernate的orm框架,deleted字段是item表中的字段 part表和item表是外键关联的但是他们的关联很特殊 他们关联的字段是两个表的主键也就是说两个表公用一个主键 我现在要对以下这段代码进行修改要在 criteria中加入一个条件内容是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-11 20:51:31 浏览: 62
你可以在 `createSpecification` 方法中添加一个条件,使其包含一个 `item.deleted` 字段为 `null` 的约束条件,如下所示:
```
private Specification<Part> createSpecification(PartCriteria criteria) {
Specification<Part> specification = Specification.where(null);
if (criteria != null) {
if (criteria.getItem() != null) {
specification = specification.and((root, query, criteriaBuilder) -> {
Join<Part, Item> itemJoin = root.join("id", JoinType.INNER).join("item", JoinType.LEFT);
return criteriaBuilder.isNull(itemJoin.get("deleted"));
});
}
// other criteria...
}
return specification;
}
```
在这个例子中,我们使用了一个左外连接来关联 `item` 表,并在连接条件中添加了一个 `item.deleted` 字段为 `null` 的约束条件,表示只查询 `item.deleted` 为 `null` 的记录。需要注意的是,这里我们使用了 `root.join("id", JoinType.INNER)` 来关联主键字段,因为在你的情况下,`Part` 表和 `Item` 表公用一个主键。
阅读全文