一、基础条件判断:<if> 标签
-
核心作用:实现简单的条件判断,根据条件决定是否拼接标签内的 SQL 片段(动态 SQL 的基础)
-
核心属性:
test,用于指定判断表达式(遵循 OGNL 表达式规则) -
经典应用:非空判断(同时处理
null值和空字符串),表达式为param != null and param != '' -
OGNL 表达式注意事项:
- 逻辑与使用
and,逻辑或使用or(而非 Java 中的&&、||) - 避免直接调用 Java 的
isEmpty()方法(可能引发空指针异常,且 OGNL 支持性不佳) - 参数直接引用名称即可,无需使用
#{}或${}包裹进行判断
- 逻辑与使用
二、条件查询优化:<where> 标签
-
核心作用:简化
WHERE子句的动态拼接,自动处理无效条件带来的 SQL 语法错误 -
两大智能功能(考题高频考点):
- 当内部有有效条件时,自动为 SQL 添加
WHERE关键字 - 智能去除条件片段开头多余的
AND或OR关键字 (仅处理开头,无法处理结尾的多余AND/OR)
- 当内部有有效条件时,自动为 SQL 添加
-
等价替代:可通过
<trim>标签模拟,对应写法为<trim prefix="WHERE" prefixOverrides="AND|OR">(区分prefixOverrides(覆盖前缀)和suffixOverrides(覆盖后缀)) -
补充说明:无需与
<if>标签强制配合使用(但实际开发中几乎都与<if>搭配实现多条件动态查询),若内部无有效条件,不会生成WHERE关键字
三、更新语句优化:<set> 标签
- 核心作用:专为
UPDATE语句设计,动态生成SET子句,解决更新字段拼接的语法问题 - 核心智能功能:自动去除
SET子句末尾多余的逗号(避免因部分字段不更新而出现 SQL 语法错误) - 等价替代:可通过
<trim>标签模拟,对应写法为<trim prefix="SET" suffixOverrides=","> - 区分要点:与参数设置无关(参数设置使用
#{...}或${...}),与 MyBatis 缓存机制无任何关联
四、集合遍历:<foreach> 标签
-
核心作用:遍历集合(List、Array、Map 等),实现批量操作(如批量删除、批量插入),常拼接
IN子句 -
核心属性(考题填空 / 单选高频考点):
collection:指定要遍历的集合名称(支持 list、array、Map 的 key、@Param 注解指定名、POJO 集合属性名)item:指定循环中当前元素的别名(变量名),用于在标签内引用当前元素index:可选属性,指定循环的索引(List / 数组为索引值,Map 为键)separator:指定循环元素之间的分隔符(如,,用于拼接IN (1,2,3)中的逗号)
-
典型应用:批量删除(遍历 ID 集合,拼接
DELETE FROM table WHERE id IN (...))
五、辅助知识点
- 模糊查询:SQL 关键字
LIKE,配合 MyBatis 中的字符串拼接函数CONCAT()(避免直接拼接字符串引发 SQL 注入,也可使用#{...}配合通配符) - 动态 SQL 标签的基础对应关系:条件判断
<if>-test、集合遍历<foreach>-item/index、条件查询<where>-AND/OR
六、易错区分知识点
<where>与<trim>的属性区分:prefix(添加前缀)、prefixOverrides(去除前缀)、suffixOverrides(去除后缀)<foreach>各属性的对应关系:避免混淆collection(集合名)、item(当前元素)、separator(分隔符)、index(索引)- OGNL 表达式与 Java 语法的区分:逻辑运算符使用
and/or,而非&&/||