PropertyPlaceholderConfigurer 無效的問題

問題描述: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>
相關文章
相關標籤/搜索