您的位置:首页 > 运维架构

Mybatis使用时Propertyplaceholderconfigurer导出配置数据无法读入

2016-12-01 00:00 417 查看
造成这种情况的原因是因为读取配置文件操作早于Propertyplaceholderconfigurer加载配置文件,导致读取配置文件时直接读取了硬编码的键名,而非键值

在使用mybatis的自动扫描注入时导致这种情况是因为使用了sqlSessionFactoryBean,例如:

<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- mapper接口所在位置 -->
<property name="basePackage" value="com.yumei.batchpay.common.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.batchpay.common.dal.daointerface" />
<!-- 注意此处为sqlSessionFactoryBeanName而不是sqlSessionFactoryBean -->
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>

但是有时候发现就算这样写还是会失效,原因是因为在applicationContext中配置了自动注入,所以就算没有配置sqlSessionFactoryBean,也没自动注入了,当然也就提前被装配了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐