首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件开发 >

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

2013-08-01 
spring 3.2 与mybatis 整合数据源出错的问题配置文件如下:context:property-placeholder locationclass

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>

热点排行