动态sql
<if> 如果则加上一段代码
<where>where 元素只会在子元素返回任何内容的情况下才插入 “WHERE” 子句。而且,若子句的开头为 “AND” 或 “OR”,where 元素也会将它们去除
<choose>类似java中从case
<when>当第一个when元素中的执行条件为真,则只动态组装第一个when元素的SQL,否则就继续判断第二个when元素中的条件是否为真
<set>会成功拼接条件,最后一个”,”号会被去掉
<foreach>对集合进行遍历
一个foreach的例子:
<select id="queryBlogForeach" parameterType="map" resultType="blog">
select * from blog
<where>
<!--
collection:指定输入对象中的集合属性
item:每次遍历生成的对象
open:开始遍历时的拼接字符串
close:结束时拼接的字符串
separator:遍历对象之间需要拼接的字符串
select * from blog where 1=1 and (id=1 or id=2 or id=3)
-->
<foreach collection="ids" item="id" open="and (" close=")" separator="or">
id=#{id}
</foreach>
</where>
</select>