elementui+vue通过下拉框多选字段进行搜索模糊匹配

从字典中选择的值为["01","03"],在最开始的时候进行的处理是类似于表单提交的时候将json对象转换成了String类型

nature:["01","03"]

javascript 复制代码
 this.queryParams.nature =JSON.stringify(this.queryParams.nature);

mapper层

java 复制代码
<if test="nature != null  and nature != ''">and naturelike concat('%', #{nature}, '%')</if>

导致报错

Caused by: java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'like concat('%', '["01","03"]', '%')

问题可能出在尝试构造一个LIKE查询来搜索包含某个数组表示形式的文本。在SQL中直接使用如'["01"]'这样的字符串,并尝试通过CONCAT函数将其嵌入到LIKE模式中通常是不直接支持的,特别是当数据库期望的是一个简单的百分号(%)引导的模式时,对于这种情况,需要对SQL语句进行更复杂的处理,因为LIKE和CONCAT无法直接处理数组。一种可能的解决方案是将nature参数拆分为多个部分并在IN子句中使用

解决:

将数组转换成了以逗号分隔的字符串

nature:01,04

javascript 复制代码
this.queryParams.nature =this.queryParams.nature.join(',');

mapper层

1.添加了foreach语句,用于遍历 nature 属性的值。split(',') 会将字符串 nature 使用逗号分割成一个字符串数组。item 是数组中的当前元素,index 是当前元素的索引,collection 是要遍历的集合(这里是分割后的数组)。

2.open="(" 和 close=")": 这两个属性分别设置了循环开始和结束的括号。在 SQL 中,LIKE 条件通常会用括号包围,尤其是当有多个 OR 条件时,以确保逻辑正确。

3.separator="or": 这个属性定义了在每个元素之间插入的分隔符。在这里,我们使用 or,意味着在每个 LIKE 条件之间添加 OR,形成类似 (nature like '%value1%' or nature like '%value2%' ...) 的结构。

java 复制代码
<if test="nature != null  and nature != ''">
                <foreach item="item" index="index" collection="nature.split(',')" open="(" close=")" separator="or">
                    nature like concat('%', #{item}, '%')
                </foreach>
            </if>
相关推荐
Ticnix3 分钟前
NestJs--Prisma 7的安装与数据库配置(超完整)
前端·nestjs
Bacon8 分钟前
CDP、Puppeteer 与无头浏览器:它们到底什么关系?
前端·javascript·node.js
kyriewen9 分钟前
你的网站被“下毒”了?XSS和CSRF:前端安全的两大“毒瘤”
前端·javascript·安全
Irene19919 分钟前
Web前端开发转行大数据开发,可行性分析及学习路线
大数据·前端·转行
咸鱼翻身了么10 分钟前
大文件上传-spark-md5
前端·后端
API快乐传递者10 分钟前
Python 爬虫获取 1688 商品详情 API 接口实战指南
java·前端·python
PeterMap12 分钟前
Vue条件渲染详解:v-if、v-show用法与实战指南
前端·vue.js
Hilaku13 分钟前
别再用 JSON.parse 深拷贝了,聊聊 StructuredClone
前端·javascript·vue.js
暗不需求14 分钟前
手写 instanceof:从原型链聊聊 JS 的实例判断
前端·javascript
像我这样帅的人丶你还16 分钟前
🔥🔥🔥Next + Tiptap + Yjs + Hocuspocus实现文档协同
前端·node.js