第八章 动态SQL
2020-04-08 本文已影响0人
Y_Jaaao
动态SQL中的元素介绍
动态SQL有什么作用
- MyBatis提供了对SQL语句动态组装的功能
动态SQL中的元素
data:image/s3,"s3://crabby-images/76338/76338ebf3e222c790efacae980874a2f04864545" alt=""
if元素
-
<if>元素是最常用的判断语句,主要用于实现某些简单的条件选择
示例
choose-when-otherwise元素
data:image/s3,"s3://crabby-images/f17be/f17beb6c498a4ab60349b0f353f762e499baa465" alt=""
data:image/s3,"s3://crabby-images/1d239/1d23971cf5495dda8fe901cb6ebeb2f38a5d2b65" alt=""
<where>元素
- 在映射文件中编写的SQL后面都加入“where 1=1”的条件。如果将“1=1”去掉,则会出现SQL语句语法错误。如下:
加入条件“1=1”后,既保证了where后面的条件成立,又避免了where后第一个词是and/or等关键词
<where>
<trim>元素
-
通过trim标签,动态构建where条件(prefix="where")
<trim>
prefixOverrides 属性
- 通过prefixOverrides="and" 去掉动态构建where条件的第一个and。
- 会忽略通过管道分隔的文本序列(注意此例中的空格也是必要的)。
- 作用是移除所有指定在 prefixOverrides 属性中的内容,并且插入 prefix 属性中指定的内容。
<set>元素
-
主要作用:用于更新操作,在动态包含的SQL语句前输出一个SET关键字,并将SQL语句中最后一个逗号去除
示例
<foreach>元素
data:image/s3,"s3://crabby-images/5d38f/5d38fc65beb75b7e9259d0fca44bce592647a2dc" alt=""
<foreach>主要属性
data:image/s3,"s3://crabby-images/a82c9/a82c9cda44c00abb8caf64d9f4abe5387a3d074b" alt=""
<foreach>中collection属性的注意事项
data:image/s3,"s3://crabby-images/8257a/8257a5157a3f899354cf1dd7b8e1cdf73d5d24e8" alt=""
<bind>元素
-
<bind>元素可以通过OGNL表达式创建一个上下文变量,方法如下:
示例