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取值 第二课堂 ,就可以正常查询到数据


原文地址:https://www.cnblogs.com/charlottepl/p/14696944.html