本文主要是介绍Mybatis中动态的<trim>标签作用,以及#{jdbcType}的用处,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
例子
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>标签作用,以及#{jdbcType}的用处的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!