动态 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,而非&&/||
相关推荐
摇滚侠10 分钟前
JDBC 基础到高级一套通关!基础篇 00-15
java·开发语言·数据库
Amnesia0_011 分钟前
MYSQL操作
数据库·mysql
兆。14 分钟前
LangChain实验跟踪集成指南:面向ML研究员
数据库·langchain
zhojiew15 分钟前
DuckLake湖仓数据格式常用操作实践以及和Iceberg的对比
数据库
万粉变现经纪人17 分钟前
2026最新CSDN博客质量分v6.0深度解读:从评分机制到80+实战提分指南
数据库·人工智能·深度学习·csdn·csdn博客·csdn博客质量分6.0·博客质量分
曹牧35 分钟前
Oracle:嵌套子查询
数据库·oracle
王莎莎-MinerU36 分钟前
Agent 时代,科学数据 API 需要重新设计
大数据·前端·数据库·人工智能·个人开发
jghhh0136 分钟前
MATLAB蒙特卡罗方法求解伊辛模型
数据库·人工智能·matlab
程序猿乐锅37 分钟前
【MySQL | 第五篇】 MySQL 性能分析:如何查询慢 SQL
java·sql·mysql
一个天蝎座 白勺 程序猿39 分钟前
时序大模型云服务快速上手:定义与核心能力
数据库·iotdb·云服务·timechoai