例子
select * from user
<trim perfix='values (' suffix=')' suffixOverrides=','>
<if test="userId != null">
#{userId,jdbcType=CHAR},
</if>
<if test="loginName != null">
#{loginName,jdbcType=VARCHAR},
</if>
</trim>
perfix 表示前面加什么
suffix 表示后面加什么
suffixOverrides 表示最后一项去掉什么
perfixOverrides 表示第一项去掉什么
jdbcType
在执行SQL时MyBatis会自动通过对象中的属性给SQL中参数赋值,它会自动将Java类型转换成数据库的类型。而一旦传入的是null 程序就无法准确判断这个类型应该是什么(是Integer?是VARCHAR?还是别的?),就有可能将类型转换错误,从而报错。
加入jdbcType正是为了解决这样的报错,需要针对这些可能为空的字段,手动指定其转换时用到的类型。
一般情况下,我们没有必要按个字段去识别/判断它是否可以为空,而是将所有的字段都当做可以为空,全部手动设置转换类型。

总结
Mybatis的补充

本文详细解析了MyBatis中的trim元素,包括prefix前缀、suffix后缀、suffixOverrides去除逗号以及jdbcType的作用。trim元素主要用于动态SQL拼接,避免空值时引发的类型转换错误。理解jdbcType的重要性在于确保null值转换时不出现类型混淆。
489

被折叠的 条评论
为什么被折叠?



