标签:sel 自动 where 功能 upd str block pre user
where、set、trim 三个标签都是为了解决 MyBatis 在动态生成 SQL 时,产生了多余的前缀和后缀的问题。
<select id="selectUserByIdAndName" resultType="com.imooc.mybatis.model.User">
SELECT * FROM imooc_user
<where>
<if test="id != null">
id = #{id}
</if>
<if test="username != null">
AND username = #{username}
</if>
</where>
</select>
在这个例子中,id 和 username 均非固定的过滤参数,只有当其不为 null 时才会加入到 SQL 语句中。此处 where 标签的作用大概有如下 3 个:
SELECT * FROM imooc_user
;SELECT * FROM imooc_user WHERE username = ?
。<update id="updateUsernameAndScoreById">
UPDATE imooc_user
<set>
<if test="username != null">
username = #{username},
</if>
id = #{id}
</set>
WHERE id = #{id}
</update>
set 标签会自动在 SQL 语句中添加上相应的 SET 前缀,并根据里面的条件动态地添加相应的字段。
由于 SQL update 的语法问题,若 set 标签里面条件均不满足,此时 set 标签也不会添加上 SET 前缀,但此时 SQL 会报语法错误,所以 set 标签中还是得有一个必然存在的赋值。
<update id="updateUsernameAndScoreById">
UPDATE imooc_user
<trim prefix="SET" suffixOverrides=",">
<if test="username != null">
username = #{username},
</if>
<if test="id != null">
id = #{id}
</if>
</trim>
WHERE id = #{id}
</update>
这里的 trim 实例实现了与 set 实例同样的功能,set 标签是 trim 标签的一种特殊情况。
trim 标签共有 4 个属性,它们的作用分别如下:
这个例子中,trim 标签的前缀为SET
,后缀覆盖属性为,
,所以在标签内不为空的情况下给 SQL 语句添加了 SET 关键字,且标签内若有多余的,
后缀也会被丢弃。
标签:sel 自动 where 功能 upd str block pre user
原文地址:https://www.cnblogs.com/qiuwenli/p/13413297.html