<MyBatis>前台传参为数组,后台SQ查询案例;

一般用于多选场景:多选查询;

如下图所示:

传值:"status" : "保存","关闭",

不传值:"status": \[\],

传给后台:

控制层:

java 复制代码
	@PostMapping(value = "/getList")
    @AuthInterceptor("mcg:getxxx:getList")
    public Result getList(HttpServletRequest request,@RequestBody String param) {
        try {
            Map<String, Object> paramMap = JsonUtils.readValue(param, Map.class);
            return Result.success().result(xxxService.getList(request,paramMap));
        } catch (Exception e) {
            log.error("XxxListController getList is error===:" + e.getMessage(), e);
            return Result.failure("据查询失败");
        }
    }
    

Mapper.xml层:

sql 复制代码
    <if test = "null != status and status.size > 0">
        and status in
        <foreach collection="status" item="item" open="(" separator="," close=")">
            #{item}
        </foreach>
    </if>
  	

疑问:

按理来说:前台传入的status 为数组类型,SQ 中if条件判断应该是:and status.length > 0,但是这样会报错,

所以最后选择:and status.size> 0;

欢迎给位大佬指点迷津!

相关推荐
Albart5757 小时前
Python 实战教程:用 30 分钟学会解决真实问题
开发语言·python
数据库小学妹7 小时前
PostgreSQL迁移到国产数据库怎么做?评估、改造、上线全流程实操指南
数据库·经验分享·postgresql·dba
2301_773643627 小时前
ceph池
开发语言·ceph·python
x***r1517 小时前
Redis Desktop Manager 0.8.8 安装教程(Windows redis-desktop-manager-0.8.8.384详细步骤)
数据库·windows·redis
initialize13068 小时前
Postgresql(Oracle兼容) 到Oracle19.9字符语义
数据库·oracle
极客笔记Jack8 小时前
Scanpy AnnData 对象深度解析:高效操作数据结构的10个技巧
python
稷下元歌8 小时前
七天学会plc 加机器视觉完整笔记:S7-1200 数据类型、存储区与寻址方式(I/Q/M/DB 详解)。
网络·数据库·笔记
颜酱8 小时前
LangChain调用向量模型,存入向量数据库
python·langchain
潮起鲸落入海8 小时前
mysql 5.x源码安装
数据库·mysql
2501_928945528 小时前
七本性全面签名体系:从互递归类型到∞-范畴生成语法
python