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)");

调用接口测试

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

mybatis-plus中使用FIND_IN_SET函数_第1张图片
mybatis-plus中使用FIND_IN_SET函数_第2张图片

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

mybatis-plus中使用FIND_IN_SET函数_第3张图片
mybatis-plus中使用FIND_IN_SET函数_第4张图片

你可能感兴趣的:(字符串,数据库,java,python,mysql)