问题描述:java
这两天本身配置SPring+MyBatis遇到了个问题,搞了一天才搞定。就是PropertyPlaceholderConfigurer加载配置以后在DatasSource中的使用无效的问题。spring
如下是配置sql
<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:properties/database.properties</value> </list> </property> <property name="fileEncoding" value="utf-8"></property> </bean> <!-- 数据源1 --> <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"> <!-- 数据库基本信息配置 --> <property name="url" value="${jdbc.url}"/> <property name="driverClassName" value="${jdbc.driver}"/> <property name="username" value="${jdbc.user}"/> <property name="password" value="${jdbc.password}"/> <property name="maxIdle" value="${jdbc.maxIdle}"/> <property name="minIdle" value="${jdbc.minIdle}"/> <property name="initialSize" value="${jdbc.initialSize}"/> <property name="timeBetweenEvictionRunsMillis" value="60000"/> <property name="poolPreparedStatements" value="true"/> <property name="maxOpenPreparedStatements" value="50"/> <property name="removeAbandonedTimeout" value="180"/> </bean> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"></property> </bean> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="mapperLocations" value="classpath:com/lubby/dao/*.xml"/> <property name="dataSource" ref="dataSource"/> </bean> <bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.lubby.dao"></property> <property name="sqlSessionFactory" ref="sqlSessionFactory"/> </bean>
思考方向:数据库
1.在思考的过程当中,想考虑了是否是Spring版本的问题,因此试了好几个版本,最后结果都是同样,PropertyPlaceholderConfigurer加载的配置依旧无效。apache
2.而后思考是否是数据源有问题,而后从c3p0数据源换成了dbcp2数据源。结果依然是PropertyPlaceholderConfigurer加载的配置无效。mybatis
真正缘由:app
MapperScannerConfigurer中若是经过SqlSessionFactory注入进去会致使DataSource提早实例化,PropertyPlaceholderConfigurer在其以后实例化,致使取到配置文件中的值。其实仔细看setSqlSessionFactory(SqlSessionFactory sqlSessionFactory)中已经注释了@Deprecated,url
@deprecated Use {@link #setSqlSessionFactoryBeanName(String)} instead.
解决办法:spa
使用sqlSessionFactoryBeanName,这样只是传进去一个String,会在PropertyPlaceholderConfigurer工做完成以后实例化DataSource。code
<bean id="mapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.lubby.dao"></property> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property> </bean>