是要分页查询part表然后加了一个条件 条件是他关联的item表中的字段deleted为null 明白了笨比
时间: 2024-03-12 08:43:08 浏览: 18
非常抱歉之前我的回答没有完全符合您的需求。根据您最新的需求描述,您想要查询 part 表中已删除的记录,并且确保关联的 item 表中的 deleted 字段为 null。
如果我理解正确,您可以尝试以下查询条件:
```
this.partService.query({
page: pageToLoad - 1,
size: this.itemsPerPage,
sort: this.sort(),
deleted: true,
'item.deleted': null
})
```
这个查询条件使用了两个条件:deleted 和 'item.deleted'。其中 deleted 表示查询 part 表中已删除的记录,'item.deleted' 表示查询关联的 item 记录的 deleted 字段为 null。
使用这个查询条件,您可以检索到 part 表中已删除的记录,并且可以确保关联的 item 记录的 deleted 字段为 null。
希望这个回答能够满足您的需求。
相关问题
select p from part p inner join item i on p.id = i.id where i.deleted is null再加一个条件item表中的字段aaa等于PART
好的,您的问题是:
请问下面这条 SQL 语句的作用是什么?
```
select p from part p inner join item i on p.id = i.id where i.deleted is null and i.aaa = 'PART'
```
这条 SQL 语句的作用是从 `part` 表和 `item` 表中选取符合条件的记录。其中,`part` 表和 `item` 表通过 `id` 字段进行关联。
具体的条件是:
- `i.deleted is null`:表示只选取 `item` 表中未被删除的记录(`deleted` 字段为 `null`)。
- `i.aaa = 'PART'`:表示只选取 `item` 表中 `aaa` 字段等于 `'PART'` 的记录。
最终结果是返回符合以上两个条件的 `part` 表中的记录。
这是一个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); }
可以在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对象返回即可。
由于是分页查询,需要在partRepository.findAll方法中传入一个Pageable对象来指定分页的信息。在修改过程中不需要对Pageable对象进行修改。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://img-home.csdnimg.cn/images/20210720083646.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)