当前位置: 代码网 > it编程>编程语言>Java > mybatis数据库查询的几种常见方法

mybatis数据库查询的几种常见方法

2026年01月14日 Java 我要评论
1、使用 or 条件查询 可以替换成sql的in条件(查询多条记录字段存一个值)querywrapper.and(!collectionutils.isempty(req.getworkshopcod

1、使用 or 条件查询 可以替换成sql的in条件(查询多条记录字段存一个值)

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)查询的值存在性

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、模糊查询

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 数组是否包含至少一个相同的值

where 	((json_overlaps(remark,	'["1","2"]'))) 只要数据库字段的数组存在查询集合的值则就会被返回

建议:

  • 确认数据库实际存储格式:先检查数据库字段的实际存储值
  • 如果存的是单个值:用方法1(or条件)
  • 如果存的是逗号分隔:用方法2(find_in_set)
  • 如果需要模糊匹配:用方法3(like查询)

到此这篇关于mybatis数据库查询的文章就介绍到这了,更多相关mybatis数据库查询内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2026  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com