动态 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,而非&&/||
相关推荐
辞旧 lekkk21 小时前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
2301_809204701 天前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277771 天前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
笨蛋不要掉眼泪1 天前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite1 天前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋91 天前
ruoyi项目更换为mysql9.7.0数据库
数据库
Andya_net1 天前
MySQL | MySQL 8.0 权限管理实践-精确赋予库、表只读等权限
android·数据库·mysql
筑梦之路1 天前
harbor数据库报错权限异常如何处理——筑梦之路
数据库·harbor
czlczl200209251 天前
理解 MySQL 行锁:两阶段锁协议与热点更新优化
数据库·mysql
AllData公司负责人1 天前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱
java·大数据·数据库·数据仓库·人工智能·python·postgresql