<sql id="selectSql">
SELECT
*
FROM
bill as b
</sql>
<select id="select" resultType="bill">
<include refid="selectSql"/>
WHERE
<if test="typeId !=null">
b.type_id_ = #{typeId}
</if>
<if test="title !=null">
and b.title_ like '%${title}%'
</if>
</select>
如果这些条件没有一个能匹配上将会怎样?最终这条 SQL 会变成这样:
SELECT * FROM bill as b where
这会导致查询失败。如果仅仅第二个条件匹配又会怎样?这条 SQL 最终会是这样:
SELECT * FROM bill as b where AND b.title_ like '%titleName%'
这个查询也会失败。
MyBatis 有一个简单的处理,这在90%的情况下都会有用。而在不能使用的地方,你可以自定义处理方式来令其正常工作。一处简单的修改就能得到想要的效果:
<sql id="selectSql">
SELECT
*
FROM
bill as b
</sql>
<select id="select" resultType="bill">
<include refid="selectSql"/>
<where>
<if test="typeId !=null">
b.type_id_ = #{typeId}
</if>
<if test="title !=null">
and b.title_ like '%${title}%'
</if>
</where>
</select>
where 元素知道只有在一个以上的if条件有值的情况下才去插入“WHERE”子句。而且,若最后的内容是“AND”或“OR”开头的,where 元素也知道如何将他们去除。
如果 where 元素没有按正常套路出牌,我们还是可以通过自定义 trim 元素来定制我们想要的功能。比如,和 where 元素等价的自定义 trim 元素为:
<trim prefix="WHERE" prefixOverrides="AND |OR "> ... </trim>