数据无法读入"/>
Mybatis使用时Propertyplaceholderconfigurer导出配置数据无法读入
2019独角兽企业重金招聘Python工程师标准>>>
造成这种情况的原因是因为读取配置文件操作早于Propertyplaceholderconfigurer加载配置文件,导致读取配置文件时直接读取了硬编码的键名,而非键值
在使用mybatis的自动扫描注入时导致这种情况是因为使用了sqlSessionFactoryBean,例如:
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- mapper接口所在位置 --><property name="basePackage" value="com.yumei.batchpaymon.dal.daointerface" /><property name="sqlSessionFactoryBean" ref="sqlSessionFactory" />
</bean>
在这种情况下,spring会提前去装配sqlSessionFactory,从而导致数据库的配置文件在Propertyplaceholderconfigurer还没加载的时候就已经被读取了,所以会连接失败。
所以需要使用另外一种配置sqlSessionFactoryBean的方式。
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- mapper接口所在位置 --><property name="basePackage" value="com.yumei.batchpaymon.dal.daointerface" /><!-- 注意此处为sqlSessionFactoryBeanName而不是sqlSessionFactoryBean --><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>
但是有时候发现就算这样写还是会失效,原因是因为在applicationContext中配置了自动注入,所以就算没有配置sqlSessionFactoryBean,也没自动注入了,当然也就提前被装配了。
转载于:
更多推荐
Mybatis使用时Propertyplaceholderconfigurer导出配置数据无法读入
发布评论