問題描述: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>