动态 SQL 的核心标签及使用细节

一、基础条件判断:<if> 标签

  1. 核心作用:实现简单的条件判断,根据条件决定是否拼接标签内的 SQL 片段(动态 SQL 的基础)

  2. 核心属性:test,用于指定判断表达式(遵循 OGNL 表达式规则)

  3. 经典应用:非空判断(同时处理null值和空字符串),表达式为 param != null and param != ''

  4. OGNL 表达式注意事项:

    • 逻辑与使用 and,逻辑或使用 or(而非 Java 中的&&||
    • 避免直接调用 Java 的isEmpty()方法(可能引发空指针异常,且 OGNL 支持性不佳)
    • 参数直接引用名称即可,无需使用#{}${}包裹进行判断

二、条件查询优化:<where> 标签

  1. 核心作用:简化WHERE子句的动态拼接,自动处理无效条件带来的 SQL 语法错误

  2. 两大智能功能(考题高频考点):

    • 当内部有有效条件时,自动为 SQL 添加WHERE关键字
    • 智能去除条件片段开头多余的ANDOR关键字 (仅处理开头,无法处理结尾的多余AND/OR
  3. 等价替代:可通过<trim>标签模拟,对应写法为 <trim prefix="WHERE" prefixOverrides="AND|OR">(区分prefixOverrides(覆盖前缀)和suffixOverrides(覆盖后缀))

  4. 补充说明:无需与<if>标签强制配合使用(但实际开发中几乎都与<if>搭配实现多条件动态查询),若内部无有效条件,不会生成WHERE关键字

三、更新语句优化:<set> 标签

  1. 核心作用:专为UPDATE语句设计,动态生成SET子句,解决更新字段拼接的语法问题
  2. 核心智能功能:自动去除SET子句末尾多余的逗号(避免因部分字段不更新而出现 SQL 语法错误)
  3. 等价替代:可通过<trim>标签模拟,对应写法为 <trim prefix="SET" suffixOverrides=",">
  4. 区分要点:与参数设置无关(参数设置使用#{...}${...}),与 MyBatis 缓存机制无任何关联

四、集合遍历:<foreach> 标签

  1. 核心作用:遍历集合(List、Array、Map 等),实现批量操作(如批量删除、批量插入),常拼接IN子句

  2. 核心属性(考题填空 / 单选高频考点):

    • collection:指定要遍历的集合名称(支持 list、array、Map 的 key、@Param 注解指定名、POJO 集合属性名)
    • item:指定循环中当前元素的别名(变量名),用于在标签内引用当前元素
    • index:可选属性,指定循环的索引(List / 数组为索引值,Map 为键)
    • separator:指定循环元素之间的分隔符(如,,用于拼接IN (1,2,3)中的逗号)
  3. 典型应用:批量删除(遍历 ID 集合,拼接DELETE FROM table WHERE id IN (...)

五、辅助知识点

  1. 模糊查询:SQL 关键字LIKE,配合 MyBatis 中的字符串拼接函数CONCAT()(避免直接拼接字符串引发 SQL 注入,也可使用#{...}配合通配符)
  2. 动态 SQL 标签的基础对应关系:条件判断<if>-test、集合遍历<foreach>-item/index、条件查询<where>-AND/OR

六、易错区分知识点

  1. <where><trim>的属性区分:prefix(添加前缀)、prefixOverrides(去除前缀)、suffixOverrides(去除后缀)
  2. <foreach>各属性的对应关系:避免混淆collection(集合名)、item(当前元素)、separator(分隔符)、index(索引)
  3. OGNL 表达式与 Java 语法的区分:逻辑运算符使用and/or,而非&&/||
相关推荐
_OP_CHEN2 小时前
【MySQL数据库基础】(三)MySQL 库的核心操作全解析:创建、修改、备份一条龙搞定
linux·数据库·sql·mysql·c/c++·mysql操作·企业级组件
数据知道2 小时前
MongoDB心跳检测与故障转移:自动主从切换的全过程解析
数据库·mongodb·wpf
古城小栈2 小时前
MongoDB go快速操控
数据库·mongodb·golang
小年糕是糕手2 小时前
【35天从0开始备战蓝桥杯 -- Day2】
开发语言·jvm·数据库·c++·程序人生·考研·蓝桥杯
数据知道2 小时前
MongoDB:如何构建“数据回收站“,防止人为误删数据(延迟节点)
数据库·mongodb
云边有个稻草人2 小时前
KingbaseES融合数据库:内核级一体化架构,实现一库多能全域支撑
数据库·国产数据库·kingbasees·金仓数据库
零基础的修炼2 小时前
Linux网络---多路转接
数据库
cookqq2 小时前
MongoDB $in查询参数上限是多少个?
数据库·mongodb
西门吹雪分身2 小时前
Mongodb存储大文件
数据库·mongodb·文件存储·gridfs