spring 3.2 与mybatis 整合数据源出错的问题
配置文件如下:
<context:property-placeholder location="classpath*:conf/jdbc.properties" /><bean id="dataSource" value="${dba.jdbc.driverClassName}" /> <property name="url" value="${dba.jdbc.url}" /> <property name="username" value="${dba.jdbc.username}" /> <property name="password" value="${dba.jdbc.password}" /></bean><!--事务 --><bean id="transactionManager"ref="dataSource" /></bean><tx:annotation-driven transaction-manager="transactionManager" /><!-- 配置SqlSessionFactoryBean --><bean id="sqlSessionFactory" ref="dataSource" /> <property name="mapperLocations" > <list> <value>classpath*:com/cnnct/product/jftcardcs/dao/*.xml"</value> <value>classpath*:com/cnnct/system/dao/*.xml"</value> </list> </property></bean><!-- scan for mappers and let them be autowired --><bean value="com.cnnct.product.jftcardcs.dao,com.cnnct.Base" /></bean>
启动时报如下错误
java.lang.IllegalStateException: Could not load JDBC driver class [${dba.jdbc.driverClassName}]
如果直接修改为非${}模式则一切正常
网上说在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。
于是配置文件修改为便解决了问题
<!-- 配置SqlSessionFactoryBean --><bean ref="dataSource" /> <property name="mapperLocations" > <list> <value>classpath*:com/cnnct/product/jftcardcs/dao/*.xml"</value> <value>classpath*:com/cnnct/system/dao/*.xml"</value> </list> </property></bean>