spring+mybatis。spring中配置BasicDataSource,读取spring-jdbc.properties中的配置:
<bean id="MySQLDataSource"
class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${mysql.db.driver}" />
<property name="url" value="${mysql.db.url}" />
<property name="username" value="${mysql.db.user}" />
<property name="password" value="${mysql.db.password}" />
<property name="maxActive" value="100"/>
<property name="maxIdle" value="10"/>
<property name="minIdle" value="5" />
<property name="maxWait" value="3000"/>
<property name="removeAbandoned" value="true"/>
<property name="removeAbandonedTimeout" value="300"/>
<property name="logAbandoned" value="true"/>
<property name="testWhileIdle" value="true"/>
<property name="validationQuery" value="SELECT 1"/>
<property name="timeBetweenEvictionRunsMillis" value="1800000"/>
<property name="minEvictableIdleTimeMillis" value="3600000"/>
</bean>
运行报错:
java.lang.ClassNotFoundException: ${jdbc.driverClass}
错误原因:
在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory。MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。
解决办法:
在3.1.1版本中配置的时候提供了sqlSessionFactoryBeanName,这时不会立即初始化sqlSessionFactory,传入的只是名字,非bean,所以不会引发提前初始化问题:
<bean id="MySQLMapperScannerConfigurer" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="MySQLSqlSessionFactory" />
<property name="annotationClass" value="org.springframework.stereotype.Repository" />
<property name="basePackage" value="com.cmss.clm" />
</bean>