配置文件如下:
<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的整合的需要的所有的jar包"的资源就是为了解决这个问题。以下是这些jar包的具体作用: 1. **Spring3.2**:这是Spring框架的版本3.2,包含核心容器、数据访问/集成、Web、AOP、工具类等...
【Spring 3.2与Mybatis 3.2整合详解】 Spring 3.2和Mybatis 3.2是两个非常流行的开源框架,它们在Java Web开发中扮演着重要角色。Spring作为一个全面的轻量级容器,负责管理对象的生命周期和依赖注入;而Mybatis则...
这是一个用Eclipse4所做的基于struts2.3、spring3.2和mybatis3.2整合的Demo,Demo中包含了详细的配置说明和初始化脚本,但不包括jar包,所以,如果需要请联系我,QQ:156296788
作用:通过传入建好的实体类、对应的java源文件包名、java源文件磁盘绝对路径、xml映射文件磁盘绝对路径后自动生成通用的CURD代码。这有助于提高开发效率,代码也显得整洁美观,易于维护。 说明: ...
SSM整合是Java Web开发中常见的一种框架组合,由Spring MVC、Spring和MyBatis三个组件构成。这个压缩包提供了一种便捷的方式,让你能在MyEclipse环境中快速搭建基于SSM的项目。以下是对这三个核心组件及其整合过程的...
Struts2、Spring和MyBatis是Java Web开发中非常重要的三个框架,它们的整合能够构建出高效、灵活的企业级应用程序。在这个项目中,我们看到的是一个基于Struts2.3、Spring3.2和MyBatis3.1的集成应用,其中使用了注释...
5. 配置数据源和事务管理器,连接MyBatis与Spring。 6. 编写实体类、Service、Controller等业务逻辑组件。 7. 在MyEclipse中导入项目,配置Tomcat服务器,运行测试。 通过这样的整合,开发者可以利用Spring MVC处理...
基于注解Spring3+SpringMVC+MyBatis3.2,工程UTF-8编码,使用MyEclipse9写的,其中Spring是自定义的User Library,如果导入的工程不能运行,请自建User Library,或者请重新创建工程,拷贝源码及相关Jar包,其中...
在"struts2.3 spring3.2 mybatis3.2整合及示例代码"项目中,开发者将这三大框架结合在一起,构建了一个完整的Java Web应用程序。这种整合旨在实现高效、松耦合的业务逻辑处理和数据访问层。下面将详细介绍这个整合...
在IT行业中,Spring框架与MyBatis的整合是常见的数据访问技术组合,它们可以提供灵活、高效的数据库操作。当我们需要处理多个数据源时,例如在分布式系统或读写分离的场景下,Spring整合MyBatis的多数据源切换就显得...
MyBatis3与Spring3.2的集成,可以方便地实现数据访问层,提供数据库操作的便利性,同时也支持动态SQL,提高了数据库操作的灵活性。 在给定的压缩包文件中,"msd_affair"可能是一个项目或者模块的名称,这可能是一个...
spring mvc 3.2 + mybatis3.2 + jsp + jstl + jquery + OSCache + freeMarker + mysql 用户登陆用统一的认证登陆接口:shiro; 前台用freeMarker 模板,还有 jsp!
Spring3 整合 MyBatis3 配置多数据源动态选择 SqlSessionFactory 详细教程 本教程主要介绍了 Spring3 整合 MyBatis3 配置多数据源动态选择 SqlSessionFactory 的详细教程。下面将详细介绍如何实现 Spring 整合 ...
在Java开发领域,Spring框架和MyBatis框架的整合是常见的数据访问技术组合。Spring作为一个全面的开源应用框架,提供依赖注入(DI)和面向切面编程(AOP)等功能,而MyBatis则是一个轻量级的持久层框架,专注于SQL...
7. **测试**:在Spring与iBatis整合后,可以使用Spring的`@Transactional`注解进行单元测试,确保每个方法都在独立的事务中执行,便于模拟各种数据状态并进行断言。 以上就是关于"Spring 3.2与iBatis整合"及"在...
在“springmvc3.2+spring3.2+mybatis3.11”这个版本中: - Spring MVC 3.2带来了更多的注解支持,改进了异常处理机制,以及对RESTful风格的支持。 - Spring 3.2版本提供了更多性能优化,提升了对Java EE 6的兼容性,...
在本文中,我们将深入探讨如何将Spring 4.0与MyBatis 3.2进行整合,特别是通过全注解的方式实现这一过程。Spring MVC是一个强大的MVC框架,而MyBatis是一个轻量级的持久层框架,两者结合可以提供高效、灵活的数据...
maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查基础开发框架.maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查基础开发框架.maven、spring、spring mvc、mybatis 整合实现ssm通用增删改查...
5. **Spring与Mybatis的整合**:通过Mybatis的SqlSessionFactoryBean和SqlSessionTemplate,将Mybatis的SqlSession管理纳入Spring的管理,实现事务的一致性。 6. **测试与运行**:通过单元测试确保各个组件正常工作...
以上就是Spring与MyBatis整合所需的关键知识点。在实际项目中,还需要根据具体需求进行适当的配置调整和优化,确保框架的高效协同工作。正确配置和理解这些概念对于Java开发者来说至关重要,因为它们构成了许多企业...