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

欢迎给位大佬指点迷津!

相关推荐
Q_Q5110082858 分钟前
python+django/flask+vue的大健康养老公寓管理系统
spring boot·python·django·flask·node.js
_院长大人_11 分钟前
MyBatis Plus 分批查询优化实战:优雅地解决 IN 参数过多问题(实操)
java·mybatis
雨中飘荡的记忆12 分钟前
SpringAI_Redis向量库实战
数据库·redis·缓存
姓蔡小朋友18 分钟前
Redis网络I/O模型
网络·数据库·redis
我是哈哈hh23 分钟前
【Python数据分析】Numpy总结
开发语言·python·数据挖掘·数据分析·numpy·python数据分析
Michelle802325 分钟前
24大数据 14-2 函数练习
开发语言·python
qq_3814549927 分钟前
Python学习技巧
开发语言·python·学习
Ndmzi33 分钟前
Matlab编程技巧:自定义Simulink菜单(理解补充)
前端·javascript·python
数据库学啊1 小时前
专业的国产时序数据库哪个好
数据库·时序数据库
dagouaofei1 小时前
AI生成个性化年终总结PPT
人工智能·python·powerpoint