mybatis-plus中使用FIND_IN_SET函数

使用场景

查询文章的方法中有一个需求是根据Tag查询,tag标签在数据库中存储的是一个字符串数组,现在前端传入一个字符串数组或者一个字符串,判断数据库中存储的数组是否包含这个数组中的元素,之前用的是like方法判断,但是如果两个标签很像的话就会查到错误的数据。

解决方法

使用mysql中的FIND_IN_SET方法可以满足这个需求

//使用find_in_set判断参数是否在数组中
            queryWrapper1.lambda().in(Activities::getOriganizationId, ids)
                    .apply(!tag.isEmpty(), "FIND_IN_SET ('" + tag + "',label)");

调用接口测试

只传 第二 的话不会查到数据

tag取值 第二课堂 ,就可以正常查询到数据


posted @ 2021-04-24 15:11  两小无猜  阅读(4810)  评论(0编辑  收藏  举报