当前位置: 首页 > article >正文

Mybatis 注意传递多种参数,不一定都有参数值,用xml如何写出查询语句

Mybatis 注意传递多种参数,不一定都有参数值,用xml如何写出查询语句

有一张User表,传递name和age参数,通过mybatis的xml格式编写查询name=like“%张%”,或者age=18的学生信息,但是注意传递name和age参数,不一定都有参数值,用xml如何写出查询语句

如果希望在 nameage 都有值的情况下,实现 name 包含给定字符串 age 等于指定值的查询,可以将 AND 改为 OR,并在判断条件时加上逻辑处理。以下是改写的 XML 查询:

<select id="selectStudentByNameOrAge" resultType="User">
    SELECT * FROM User
    WHERE 1=1
    <if test="name != null and name != ''">
        AND (name LIKE CONCAT('%', #{name}, '%')
    </if>
    <if test="age != null">
        <if test="name != null and name != ''">
            OR age = #{age})
        </if>
        <if test="name == null or name == ''">
            AND age = #{age}
        </if>
    </if>
</select>

解释

  1. WHERE 1=1 起到占位作用,简化 SQL 条件的拼接。

  2. <if test="name != null and name != ''">:判断 name 是否有值。如果有,则拼接 AND (name LIKE CONCAT('%', #{name}, '%')

  3. <if test="age != null">:判断 age 是否有值。

    是否有值。

    • 如果 agename 都有值,则拼接 OR age = #{age}),实现 nameage 的条件。
    • 如果只有 age 有值(name 为空),则拼接 AND age = #{age}

这样实现后,如果 nameage 都有值,会查询满足 name 包含指定字符串 age 等于指定值的用户。

或者

<select id="selectStudentByNameOrAge" resultType="User">
    SELECT * FROM User
    WHERE 1=1
    <if test="name != null and name != ''">
        AND (name LIKE CONCAT('%', #{name}, '%')
    </if>
    <if test="age != null">
        <if test="name != null and name != ''">
            OR
        </if>
        age = #{age})
    </if>
    <if test="name == null or name == ''">
        <if test="age != null">
            AND age = #{age}
        </if>
    </if>
</select>

解释:

  1. 使用 OR 逻辑:如果 nameage 都有值,则 nameage 的条件会被括在一起,实现 (name LIKE '%张%' OR age = 18) 的逻辑。
  2. 分支控制:
    • 如果 name 有值,先添加 name LIKE 条件;
    • 如果 age 也有值,在 name 后面添加 OR age = #{age};
    • 如果只有 age 有值,而 name 没有值,则直接在外面添加 age = #{age} 条件

http://www.kler.cn/a/380801.html

相关文章:

  • CodeQL学习笔记(5)-CodeQL for Java(AST、元数据、调用图)
  • web实操2——idea创建普通web项目
  • 【React】初学React
  • 数据库操作(php+mysql)
  • 模型 海勒姆法则(用户依赖你未承诺的API功能)
  • 代码随想录第十五天| 110.平衡二叉树 、 257. 二叉树的所有路径 、404.左叶子之和、222.完全二叉树的节点个数
  • IntelliJ IDEA插件开发-核心概念介绍
  • 【JavaScript】JavaScript开篇基础(4)
  • windows_worm
  • 医院信息化与智能化系统(15)
  • JVM结构图
  • 解决虚拟机启动报:此主机支持AMD-V,但AMD-V处于禁用状态
  • 基于Multisim光控夜灯LED电路带计时功能(含仿真和报告)
  • QT 实现自定义开机加载动画二
  • [Web安全 网络安全]-学习文章汇总导航(持续更新中)
  • k8s的发展历史
  • 1251. 平均售价(left join on后面加条件和where 后面加条件的区别、nvl()函数的使用)
  • 如何在 IntelliJ IDEA 中调整 `Ctrl+/` 快捷键生成注释的位置
  • Percona XtraBackup数据备份方案
  • Java学习教程,从入门到精通,Java对象和类语法知识点(20)
  • pdf转图片
  • Angular解析本地json文件
  • [mysql]修改表和课后练习
  • How to initiate a conversation with a stranger?
  • 【Mysql 深入探索】InnoDB 实现事务的机制
  • qt QColor详解