configuration: A MyBatis Configuration bean. About available properties see the MyBatis reference page
从那里开始并不是很明显,但我认为它的建议是你可以添加这样的东西:
mybatis.configuration.jdbcTypeForNull=VARCHAR
这似乎有效;当然,如果我将VARCHAR更改为枚举JdbcType的有效值,我会收到错误.但是,它似乎也没有恢复我的设置.
当我使用调试器时,我可以看到在Configuration.setJdbcTypeForNull()之前调用MybatisProperties.setConfiguration(),这意味着使用默认值(JdbcType.OTHER)而不是我试图设置的值.
我误解了这个功能应该如何使用,或者这是一个错误?是否有其他人设置这样的配置值?在其他地方,我只能看到使用XML文件的示例,如果可能的话,我宁愿避免使用它们.
嗯,这很尴尬
我放弃尝试在application.properties中使用配置属性,并使用我试图避免的XML配置,但刚才,在这里看到一些有用的建议,我回到我的代码,从XML配置回mybatis.configuration.jdbcTypeForNull = NULL并重新运行我的测试,这在以前的相同条件下肯定是失败的,但现在它通过了.
我不知道之前有什么不同 – 调试我看到了与上面提到的相同的行为 – 配置bean似乎在启动期间将jdbcTypeForNull参数设置回OTHER,但是当在查询期间访问它时它再次为NULL.我会在这里留下这个问题,以防它是一个竞争条件,它会在以后再次失败,但是现在我的问题似乎已经神秘地消失了.
解决方法
正如Spring引导所做的那样,在Configuration.setJdbcTypeForNull()非常正确之前调用MybatisProperties.setConfiguration().因为spring boot尝试将配置设置为MybatisProperties但发现其成员配置为null,因此spring boot将实例化一个新配置并立即将其分配给MybatisProperties.之后,spring boot将尝试将所有mybatis.configuration.*分配给MybatisProperties的此成员.
如果要使用XML配置mybatis,则需要指定< setting name =“jdbcTypeForNull”value =“VARCHAR”/>在元素< settings />下如example.
这肯定会奏效.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。