造成这种情况的原因是因为读取配置文件操作早于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,也没自动注入了,当然也就提前被装配了。