1.if语句
如果empno不为空,则在WHERE参数后加上AND empno = #{empno},这里有1=1所以即使empno为null,WHERE后面也不会报错。
映射文件
<select id="getEmpById2" resultType="emp"> SELECT * FROM emp WHERE 1=1 <if test="empno != null"> AND empno = #{empno} </if> </select>
EmpMapper接口
public Emp getEmpById2(@Param("empno")Integer empno) throws IOException;
有时候我们并不想应用所有的条件,而只是想从多个选项中选择一个。而使用if标签时,只要test中的表达式为 true,就会执行 if 标签中的条件。MyBatis 提供了 choose 元素。if标签是与(and)的关系,而 choose 是或(or)的关系。
2.where语句和Choose(when,otherwise)
1.Where后面empno和ename为null,那where就不会出现在sql语句中。
2. choose标签是按顺序判断其内部when标签中的test条件出否成立,如果有一个成立,则 choose 结束。当 choose 中所有 when 的条件都不满则时,则执行 otherwise 中的sql。类似于Java 的 switch 语句,choose 为 switch,when 为 case,otherwise 则为 default。
映射文件
<select id="getEmpById3" resultType="emp" parameterType="emp"> SELECT * FROM EMP <where> <choose> <when test="empno != null"> AND empno like #{empno} </when> <when test="ename != null"> AND ename like #{ename} </when> <otherwise> AND job = "zz" </otherwise> </choose> </where> </select>
3.set语句
set主要也是用来解决更新问题的。
映射文件
<update id="updateEmprById2" parameterType="emp"> UPDATE emp <set> <if test="ename!=null"> ename=#{ename},</if> <if test="job!=null"> job=#{job},</if> </set> <where> <if test="empno!=null"> empno=#{empno}; </if> </where> </update>
4.trim
trim标记是一个格式化的标记,可以完成set或者是where标记的功能。
相关属性:
Prefix:前缀。
prefixOverrides:去掉第一个指定内容。
suffix:后缀。
suffixoverride:去掉最后一个指定内容。
映射文件
<!-- 代替where --> <select id="getEmpById4" resultType="emp" parameterType="emp"> SELECT * FROM emp <!-- <where> <if test="username!=null"> and name = #{username} </if> </where> --> <trim prefix="where" prefixOverrides="AND |OR "> <if test="empno != null"> and empno = #{empno} </if> <if test="ename!=null"> AND ename = #{ename} </if> </trim> </select>
映射文件
<!-- 代替set --> <update id="updateEmprById3" parameterType="emp"> update emp <trim prefix="set" suffixOverrides=","> <if test="ename!=null"> ename = #{ename}, </if> <if test="job != null"> job = #{job} </if> </trim> <trim prefix="where" prefixOverrides="AND |OR "> <if test="empno != null"> and empno = #{empno} </if> </trim> </update>
5.foreach语句
foreach用来遍历,遍历的对象可以是数组,也可以是集合。
相关属性:
Collection:collection属性的值有三个分别是list、array、map三种。
Open:前缀。
Close:后缀。
Separator:分隔符,表示迭代时每个元素之间以什么分隔。
Item:表示在迭代过程中每一个元素的别名。
Index:用一个变量名表示当前循环的索引位置。
映射文件
<insert id="addEmp6"> insert into emp(ename,job)values <foreach collection="emps" item="emp" separator=","> (#{emp.ename},#{emp.job}) </foreach> </insert>
6.SQL块
映射文件
<!-- 定义重复使用的SQL内容 --> <sql id="baseSql"> empno,ename,job </sql> <!-- 使用include引入sql块 --> <select id="selEmp1" resultType="emp"> select <include refid="baseSql"/> from emp </select>