MyBatismybatis 中sql

1   if标签

if标签的基本功能就和if功能差不多,只是在if标签中她会叫起几乎独规范去看清,如果条件不建则无见面履
if标签中之sql语句

<select id=" getStudentListLikeName " parameterType="StudentEntity"  
resultMap="studentResultMap">
 SELECT * from STUDENT_TBL ST
 <if test="studentName!=null and studentName!='' ">
  WHERE ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
 </if>
</select>

2  where标签

where标签和sql中之where功能差不多,只是以where的基本功及补偿加了一些初的成效

假使其富含的价签中起返回值的说话虽栽一个where。

另外要标签返回的情节是以AND或OR开头的,则它会剔除掉。

<select id="getStudentListWhere" parameterType="StudentEntity"

 resultMap="studentResultMap">
 SELECT * from STUDENT_TBL ST
 <where>
  <if test="studentName!=null and studentName!='' ">
   ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
  </if>
  <if test="studentSex!= null and studentSex!= '' ">
   AND ST.STUDENT_SEX = #{studentSex}
  </if>
 </where>
</select>

3  set标签

动用set+if标签修改后,如果有项也null则非进行更新,而是保持数据库原值

<update id="updateStudent" parameterType="StudentEntity">
 UPDATE STUDENT_TBL
 <set>
  <if test="studentName!=null and studentName!='' ">
   STUDENT_TBL.STUDENT_NAME = #{studentName},
  </if>
  <if test="studentSex!=null and studentSex!='' ">
   STUDENT_TBL.STUDENT_SEX = #{studentSex},
  </if>
  <if test="studentBirthday!=null ">
   STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
  </if>
  <if test="classEntity!=null and classEntity.classID!=null and classEntity.classID!='' ">
   STUDENT_TBL.CLASS_ID = #{classEntity.classID}
  </if>
 </set>
 WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
</update>

 

4  trim标签

trim是重复灵敏的去处多余关键字之标签,他可以履where和set的功力。

trim要素的重要作用是好于友好带有的情前面增长一些前缀,也得以该后长一些后缀,与的相应的性能是
prefix和suffix;

可管带有内容的首部某些内容覆盖,即忽略,也足以把尾部的少数内容覆盖,

对应之性能是prefixOverrides
suffixOverrides;正缘trim有这样的功能,

据此我们呢得以非常简单的采取trim来代替where元素的功效。

where例子的等效trim语句

<select id="getStudentListWhere" parameterType="StudentEntity" resultMap="studentResultMap">
 SELECT * from STUDENT_TBL ST
 <trim prefix="WHERE"="AND|OR">
  <if test="studentName!=null and studentName!='' ">
   ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
  </if>
  <if test="studentSex!= null and studentSex!= '' ">
   AND ST.STUDENT_SEX = #{studentSex}
  </if>
 </trim>
</select>



set例子的等效trim语句

<update id="updateStudent" parameterType="StudentEntity">
 UPDATE STUDENT_TBL
 <trim prefix="SET" suffixOverrides=",">
  <if test="studentName!=null and studentName!='' ">
   STUDENT_TBL.STUDENT_NAME = #{studentName},
  </if>
  <if test="studentSex!=null and studentSex!='' ">
   STUDENT_TBL.STUDENT_SEX = #{studentSex},
  </if>
  <if test="studentBirthday!=null ">
   STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
  </if>
  <if test="classEntity!=null and classEntity.classID!=null and classEntity.classID!='' ">
   STUDENT_TBL.CLASS_ID = #{classEntity.classID}
  </if>
 </trim>
 WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
</update>

5 choose标签

choose (when, otherwise)

偶尔并无思行使拥有的条件,而一味是纪念打多只选项MyBatis中挑选一个。MyBatis提供了choose
元素,

准梯次判断when中的标准化出否成立,设来一个建,则choose结束。当choose中享有when的口径且未充满则经常,

则执行otherwise中的sql。类似于Java
的switch语句,choose为switch,when为case,otherwise则为default。

<select id="getStudentListChooseEntity" parameterType="StudentEntity" resultMap="studentResultMap">
 SELECT * from STUDENT_TBL ST
 <where>
  <choose>
   <when test="studentName!=null and studentName!='' ">
    ST.STUDENT_NAME LIKE CONCAT(CONCAT('%', #{studentName}),'%')
   </when>
   <when test="studentSex!= null and studentSex!= '' ">
    AND ST.STUDENT_SEX = #{studentSex}
   </when>
   <when test="studentBirthday!=null">
    AND ST.STUDENT_BIRTHDAY = #{studentBirthday}
   </when>
   <when test="classEntity!=null and classEntity.classID !=null and classEntity.classID!='' ">
    AND ST.CLASS_ID = #{classEntity.classID}
   </when>
   <otherwise></otherwise>
  </choose>
 </where>
</select>

6 foreach

对动态SQL 非常必须的,主是要迭代一个聚众,通常是用于IN 条件。

List实例将祭“list”做为键,数组实例以“array”做为键。

网站地图xml地图