spring 3.2 与mybatis 整合数据源出错的有关问题
spring 3.2 与mybatis 整合数据源出错的问题
配置文件如下:
启动时报如下错误
如果直接修改为非${}模式则一切正常
网上说在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。
于是配置文件修改为便解决了问题
配置文件如下:
<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>