1、使用 OR 条件查询 可以替换成SQL的IN条件(查询多条记录字段存一个值)
sql
queryWrapper.and(!CollectionUtils.isEmpty(req.getWorkshopCodes()), wrapper -> {
for (String paramType : req.getWorkshopCodes()) {
wrapper.or().eq(DeviceShiftInfo::getWorkshopCode, paramType);
}
});
SQL: (workshop_code = '测试1' OR workshop_code = '测试2')
queryWrapper.in(!CollectionUtils.isEmpty(req.getWorkshopCodes()),DeviceShiftInfo::getWorkshopCode,req.getWorkshopCodes())
SQ:workshop_code IN('测试1','测试2')
2、数据库存的是逗号分隔的字符串(存的是测试1,测试2)查询的值存在性
sql
queryWrapper.and(!CollectionUtils.isEmpty(req.getWorkshopCodes()), wrapper -> {
for (String paramType : req.getWorkshopCodes()) {
wrapper.or()
.apply("FIND_IN_SET({0}, workshop_code)", paramType);
}
});
SQL:WHERE ((FIND_IN_SET('1', workshop_code) OR FIND_IN_SET('2', workshop_code)))
3、模糊查询
sql
queryWrapper.and(!CollectionUtils.isEmpty(req.getWorkshopCodes()), wrapper -> {
for (String paramType : req.getWorkshopCodes()) {
wrapper.or().like(DeviceShiftInfo::getWorkshopCode, paramType);
}
});
SQL: WHERE ((workshop_code LIKE '%1%' OR workshop_code LIKE '%2%'))
4、数据库存的是数组
假如库里存数组
JSON_OVERLAPS() 是 MySQL 8.0.17 及以上版本引入的一个函数,用于判断两个 JSON 文档是否存在重叠(overlap)的元素。它常用于比较两个 JSON 数组是否包含至少一个相同的值 
sql
WHERE ((JSON_OVERLAPS(remark, '["1","2"]'))) 只要数据库字段的数组存在查询集合的值则就会被返回
建议:
- 确认数据库实际存储格式:先检查数据库字段的实际存储值
- 如果存的是单个值:用方法1(OR条件)
- 如果存的是逗号分隔:用方法2(FIND_IN_SET)
- 如果需要模糊匹配:用方法3(LIKE查询)