`

spring 3.2 与mybatis 整合数据源出错的问题

 
阅读更多
配置文件如下:
<context:property-placeholder location="classpath*:conf/jdbc.properties" />
	<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName" 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"
		class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource" />
	</bean>
	<tx:annotation-driven transaction-manager="transactionManager" />
	
	<!-- 配置SqlSessionFactoryBean -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" 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 class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="basePackage" 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 class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" 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>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics