mybatis数据库查询

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查询)
相关推荐
倔强的石头_8 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤2 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区3 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号34 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏4 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐4 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再4 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest4 天前
数据库SQL学习
数据库·sql