配置文件如下:
<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>
分享到:
相关推荐
Spring3.2 ,Mybatis3.2,commons-pool-1.3.jar,commons-dbcp-1.2.2.jar,mybatis-spring-1.2.2.jar
这是一个用Eclipse4所做的一个基于Spring3.2和Mybatis3.2所做的一个整合的Demo,包括初始化数据脚本,但不包括jar包
作用:通过传入建好的实体类、对应的java源文件包名、java源文件磁盘绝对路径、xml映射文件磁盘绝对路径后自动生成通用的CURD代码。这有助于提高开发效率,代码也显得整洁美观,易于维护。 说明: ...
这是一个用Eclipse4所做的基于struts2.3、spring3.2和mybatis3.2整合的Demo,Demo中包含了详细的配置说明和初始化脚本,但不包括jar包,所以,如果需要请联系我,QQ:156296788
基于注解Spring3+SpringMVC+MyBatis3.2,工程UTF-8编码,使用MyEclipse9写的,其中Spring是自定义的User Library,如果导入的工程不能运行,请自建User Library,或者请重新创建工程,拷贝源码及相关Jar包,其中...
struts2.3 spring3.2 mybatis3.2 框架整合,示例代码,实现了增删改查的功能
框架springmvc3.2+spring3.2+mybatis3.11整合附带jar包 附带jar包,直接导入myeclipse就能使用
附带jar包,直接导入myeclipse就能使用
spring mvc 3.2 + mybatis3.2 + jsp + jstl + jquery + OSCache + freeMarker + mysql 用户登陆用统一的认证登陆接口:shiro; 前台用freeMarker 模板,还有 jsp!
spring整合mybatis多数据源切换 可以运行的demo实例
一个完整的s2sm整合项目,含jar包。使用注释型事务管理。给大家参考了。
Spring mvc使用注解实现 Spring4.0与mybatis3.2整合的一个实例
主要介绍了Spring3 整合MyBatis3 配置多数据源动态选择SqlSessionFactory详细教程,需要的朋友可以参考下
Spring+SpringMVC+Mybatis多数据源整合。基于spring3.0和mybatis3.2的
spring_mybatis 整合jar包,基本常用jar包的整合,。。。。。。。。。。。。。。。
maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查基础开发框架.maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查基础开发框架.maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查...
struts2.3 spring3.2 mybatis3.2 lucene4.2搜索引擎
使用maven搭建整合这三个框架,导入myeclipse即可测试使用
maven spring spring mvc mybatis 整合
STS下spring boot、mybatis多数据源配置源码工程