java – 如何在Spring Boot应用程序的application.properties文件中设置MyBatis配置属性?

MyBatis Spring Boot Starter documentation列出了可以在application.properties文件中设置的属性,该列表包括

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.我会在这里留下这个问题,以防它是一个竞争条件,它会在以后再次失败,但是现在我的问题似乎已经神秘地消失了.

解决方法

如果您要使用mybatis.configuration.jdbcTypeForNull,请记住不要同时指定configLocation属性.否则,您的设置将被删除认值.

正如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.

这肯定会奏效.

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...