Mybaits 使用多数据库源错误 --MapperScannerConfigurer配置
2013-12-01 17:30
393 查看
我在配置文件里面配置了一个数据源,数据源参数是根据配置文件加载。数据源在mybaits和自定义数据工具类中使用,但是启动工程后,报错如下: ### Cause: org.springframework.jdbc.CannotGetJdbcConnectionException: Could not get JDBC Connection; nested exception is org.apache.commons.dbcp.SQLNestedException: Cannot load JDBC driver class '${jdbc.driverClassName}' at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1455)
------------------------------2012年8月28日
通过错误日志,猜测是MapperScannerConfigurer早于PropertyPlaceholderConfigurer初始化的原因。
尝试将 Java代码 <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:resource/conf/jdbc.properties</value> <value>classpath:resource/conf/sys.properties</value> </list> </property> </bean> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:resource/conf/jdbc.properties</value> <value>classpath:resource/conf/sys.properties</value> </list> </property> </bean>
修改为 <util:properties id="jdbcProps" location="classpath:jdbc.properties"/>使用util:properties替代上面的propertyConfigurer。
***************************************************2012-12-05MapperScannerConfigurer初始化的时候,PropertyPlaceholderConfigurer还没有将properties的参数值替换,所有导致直接将参数名,如“${jdbc.driverClassName}”设置到dataSource的字段属性中。
同时,官方已经弃用了采用sqlSessionFactoryBean 和 SesionTemplateBean的方式进行配置,而推荐使用sqlSessionFactoryBeanName 和 sqlSessionTemplateBeanName
所以正确的配置应该为:<!-- 扫描映射器,自动创建 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="..." />
<property name="sqlSessionTemplateBeanName" value="fsasSqlSession" />
</bean>
----------------------------在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。
-------------------------------------在3.1.1版本中配置的时候提供了以下:<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.xxxx.dal.mapper" /> <property name="sqlSessionFactoryBeanName" value="ysSqlSessionFactory" /> <!-- <property name="sqlSessionFactory" ref="ysSqlSessionFactory"></property> --> </bean>改用sqlSessionFactoryBeanName注入就没有问题(不要使用sqlSessionFactory属性注入,使用sqlSessionFactoryBeanName注入),因为这时不会立即初始化sqlSessionFactory,传入的只是名字,非bean,所以不会引发提前初始化问题。
------------------------------2012年8月28日
通过错误日志,猜测是MapperScannerConfigurer早于PropertyPlaceholderConfigurer初始化的原因。
尝试将 Java代码 <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:resource/conf/jdbc.properties</value> <value>classpath:resource/conf/sys.properties</value> </list> </property> </bean> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:resource/conf/jdbc.properties</value> <value>classpath:resource/conf/sys.properties</value> </list> </property> </bean>
修改为 <util:properties id="jdbcProps" location="classpath:jdbc.properties"/>使用util:properties替代上面的propertyConfigurer。
***************************************************2012-12-05MapperScannerConfigurer初始化的时候,PropertyPlaceholderConfigurer还没有将properties的参数值替换,所有导致直接将参数名,如“${jdbc.driverClassName}”设置到dataSource的字段属性中。
同时,官方已经弃用了采用sqlSessionFactoryBean 和 SesionTemplateBean的方式进行配置,而推荐使用sqlSessionFactoryBeanName 和 sqlSessionTemplateBeanName
所以正确的配置应该为:<!-- 扫描映射器,自动创建 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="..." />
<property name="sqlSessionTemplateBeanName" value="fsasSqlSession" />
</bean>
----------------------------在spring里使用org.mybatis.spring.mapper.MapperScannerConfigurer 进行自动扫描的时候,设置了sqlSessionFactory 的话,可能会导致PropertyPlaceholderConfigurer失效,也就是用${jdbc.username}这样之类的表达式,将无法获取到properties文件里的内容。 导致这一原因是因为,MapperScannerConigurer实际是在解析加载bean定义阶段的,这个时候要是设置sqlSessionFactory的话,会导致提前初始化一些类,这个时候,PropertyPlaceholderConfigurer还没来得及替换定义中的变量,导致把表达式当作字符串复制了。 但如果不设置sqlSessionFactory 属性的话,就必须要保证sessionFactory在spring中名称一定要是sqlSessionFactory ,否则就无法自动注入。又或者直接定义 MapperFactoryBean ,再或者放弃自动代理接口方式。
-------------------------------------在3.1.1版本中配置的时候提供了以下:<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.xxxx.dal.mapper" /> <property name="sqlSessionFactoryBeanName" value="ysSqlSessionFactory" /> <!-- <property name="sqlSessionFactory" ref="ysSqlSessionFactory"></property> --> </bean>改用sqlSessionFactoryBeanName注入就没有问题(不要使用sqlSessionFactory属性注入,使用sqlSessionFactoryBeanName注入),因为这时不会立即初始化sqlSessionFactory,传入的只是名字,非bean,所以不会引发提前初始化问题。
相关文章推荐
- MapperScannerConfigurer配置多数据源,填充数据源数据时报类型转换错误
- mybatis-spring集成:配置多数据库源中遇到的问题--MapperScannerConfigurer配置
- spring 整合mybatis配置 MapperScannerConfigurer,无法读配置文件错误
- 使用MapperScannerConfigurer简化MyBatis配置
- mybatis整合spring使用MapperScannerConfigurer配置问题
- IDEA中解决spring整合mybatis后使用MapperScannerConfigurer扫描mapper包时“ Invalid bound statement (not found)”错误
- spring property-placeholder MapperScannerConfigurer无法读取配置的解决
- 关于Spring整合mybatis时配置MapperScannerConfigurer的问题
- 配置MapperScannerConfigurer
- spring3+mybatis 使用MapperScannerConfigurer时context:property-placeholder载不进属性
- org.mybatis.spring.mapper.MapperScannerConfigurer的错误
- 通过MapperScannerConfigurer配置Mybatis的一点研究
- AAAMybatis使用MapperScannerConfigurer实现自动注册dao到spring容器
- MyBatis MapperScannerConfigurer配置
- MyBatis MapperScannerConfigurer配置
- MyBatis MapperScannerConfigurer配置——MyBatis学习笔记之八
- MyBatis MapperScannerConfigurer配置——MyBatis学习笔记之一
- Mybatis使用时Propertyplaceholderconfigurer导出配置数据无法读入
- Mybatis MapperScannerConfigurer 配置
- Spring+mybatis 使用注解配置多数据库源,支持读写分离