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

欢迎给位大佬指点迷津!

相关推荐
winfredzhang2 分钟前
Python小说图片PDF生成器开发详解
python·pdf·图文并茂·电子小说
Derrick__118 分钟前
Python网络编程——TCP编程
python·网络协议·tcp/ip
huaqw0018 分钟前
Java17新特性解析深入理解SealedClasses的语法约束与设计哲学
数据库
濑户川34 分钟前
深入理解Django 视图与 URL 路由:从基础到实战
后端·python·django
lang2015092837 分钟前
MyBatis配置全解析:核心要点详解
mybatis
Jc.MJ1 小时前
安装Anaconda3与PythonCharm
python
xuejianxinokok1 小时前
新版本 python 3.14 性能到底如何?
后端·python
专职1 小时前
pytest详细教程
开发语言·python·pytest
专职1 小时前
pytest+requests+allure生成接口自动化测试报告
开发语言·python·pytest
小韩博1 小时前
day03_八大基本数类型+程序交互+基本运算符+流程控制语句
python·交互