`
wanmeilingdu
  • 浏览: 24032 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Spring3.0和Mybatis的集成,含事务配置

阅读更多
相对于hibernate来说,比较喜欢mybatis一些。虽然mybatis没有hibernate那么成熟,但可以手动控制sql语句怎么长。废话不多说,上代码。欢迎拍砖。





Xml代码 
<?xml version="1.0" encoding="UTF-8"?> 
<beans default-autowire="byType" xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"> 
    <bean id="propertyConfig" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
        <property name="locations"> 
            <list> 
                <value>classpath:spring-jdbc.properties</value> 
            </list> 
        </property> 
    </bean> 
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource"> 
        <property name="driverClassName" value="${jdbc.driver}"> 
        </property> 
        <property name="url" value="${jdbc.url}"> 
        </property> 
        <property name="username" value="${jdbc.username}"> 
        </property> 
        <property name="password" value="${jdbc.password}"> 
        </property> 
    </bean> 
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 
        <property name="configLocation" value="classpath:SqlMapConfig.xml"></property> 
        <property name="dataSource" ref="dataSource"></property> 
        <property name="mapperLocations" value="classpath*:mappers-*.xml"></property> 
    </bean> 
    <!-- 由spring管理mybatis的事物 --> 
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> 
        <property name="dataSource" ref="dataSource"></property> 
    </bean> 
    <!-- 定义拦截器,用来指定事物属性,级别,和异常处理 --> 
    <bean id="transactionInterceptor" class="org.springframework.transaction.interceptor.TransactionInterceptor"> 
        <property name="transactionManager" ref="transactionManager"></property> 
        <property name="transactionAttributes"> 
            <props> 
                <!-- PROPAGATION_SUPPORTS: 如果已经存在事务,则加入事务;如果没有事务,则以非事务的方式执行;   
                PROPAGATION_MANDATORY: 使用当前事务, 如果没有, 则抛出异常;   
                PROPAGATION_REQUIRED: 新建事务,如果当前有事务, 则挂起; P  
                ROPAGATION_NOT_SUPPORTED:以非事务的方式执行, 如果当前有事务, 则挂起;   
                PROPAGATION_NEVER:以非事务的方式执行, 如果当前有事务,则抛出异常;   
                +/-Exception</prop> + 表示异常出现时事物提交 - 表示异常出现时事务回滚 --> 
                <prop key="find*">PROPAGATION_SUPPORTS,readOnly</prop> 
                <prop key="del*"> PROPAGATION_SUPPORTS</prop> 
                <prop key="update*">PROPAGATION_REQUIRED</prop> 
                <prop key="save*">PROPAGATION_REQUIRED,-Exception</prop> 
            </props> 
        </property> 
    </bean> 
    <!-- 用来定义那些类需要采用事物管理 spring 事物的动态代理类 BeanNameAutoProxyCreator 根据类名自动代理,接受表达式 --> 
    <bean id="BeanProxy" class="org.springframework.aop.framework.autoproxy.BeanNameAutoProxyCreator"> 
        <property name="beanNames"> 
            <!-- 对类名以MybatisService结尾的类进行代理 --> 
            <value>*MybatisService</value> 
        </property> 
        <!-- 对代理类进行加载拦截器(实现通知的过程) --> 
        <property name="interceptorNames"> 
            <list> 
                <value>transactionInterceptor</value> 
            </list> 
        </property> 
    </bean> 
</beans> 




鉴于网络参数和鉴权信息是经常变的,所以单独拿出来放在属性文件中了。spring-jdbc.properties内容如下:



Java代码 
jdbc.driver=oracle.jdbc.driver.OracleDriver  
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl  
jdbc.username=admin  
jdbc.password=pwd 

jdbc.driver=oracle.jdbc.driver.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=admin
jdbc.password=pwd



Mybatis中的拦截器和一些bean的配置信息就放在SqlMapConfig.xml这个文件中了

Xml代码 
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE configuration  
PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN"  
"http://ibatis.apache.org/dtd/ibatis-3-config.dtd"> 
<configuration> 
    <!-- 要在environment之前 --> 
    <typeAliases> 
        <typeAlias type="com.jacarri.document.vo.WriteFileVo" alias="WriteFileVo" /> 
    </typeAliases> 
    <plugins> 
        <plugin interceptor="com.jacarri.common.filter.PaginationInterceptor" /> 
        <plugin interceptor="com.jacarri.common.filter.ColumnsControlInterceptor" /> 
    </plugins> 
</configuration> 

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN"
"http://ibatis.apache.org/dtd/ibatis-3-config.dtd">
<configuration>
<!-- 要在environment之前 -->
<typeAliases>
<typeAlias type="com.jacarri.document.vo.WriteFileVo" alias="WriteFileVo" />
</typeAliases>
<plugins>
<plugin interceptor="com.jacarri.common.filter.PaginationInterceptor" />
<plugin interceptor="com.jacarri.common.filter.ColumnsControlInterceptor" />
</plugins>
</configuration>备注:两个interceptor,第一个是用来分页的,第二个是用来控制select语句中列名的,就不上代码了。想要的可以给我发消息。至于WriteFileVo就是一个普通的bean,如果你要用到缓存,记得bean要实现java.io.Serializable。





同时附上jar包清单(该清单是在搭建struts2+Spring3+Mybatis框架时用到的清单)





Java代码 
antlr-2.7.6.jar  
aopalliance.jar  
asm-2.2.3.jar  
asm-commons-2.2.3.jar  
backport-util-concurrent-3.1.jar  
cglib-nodep-2.1_3.jar  
commons-collections-3.1.jar  
commons-dbcp-1.2.1.jar  
commons-fileupload-1.2.1.jar  
commons-io-1.3.2.jar  
commons-lang-2.3.jar  
commons-logging-1.1.1.jar  
commons-pool-1.2.jar  
dom4j-1.6.1.jar  
ehcache-1.5.0.jar  
freemarker-2.3.15.jar  
jakarta-oro-2.0.8.jar  
javassist-3.12.0.GA.jar  
json-lib-2.1-jdk15.jar  
jta.jar  
log4j-1.2.16.jar  
mybatis-3.0.6-SNAPSHOT.jar  
mybatis-spring-1.0.2-SNAPSHOT.jar  
mysql-connector-java-5.1.17-bin.jar  
ognl-2.7.3.jar  
org.springframework.aop-3.1.0.M2.jar  
org.springframework.asm-3.1.0.M2.jar  
org.springframework.beans-3.1.0.M2.jar  
org.springframework.context-3.1.0.M2.jar  
org.springframework.core-3.1.0.M2.jar  
org.springframework.expression-3.1.0.M2.jar  
org.springframework.jdbc-3.1.0.M2.jar  
org.springframework.orm-3.1.0.M2.jar  
org.springframework.transaction-3.1.0.M2.jar  
org.springframework.web-3.1.0.M2.jar  
struts2-config-browser-plugin-2.2.1.jar  
struts2-convention-plugin-2.2.1.jar  
struts2-core-2.2.1.jar  
struts2-json-plugin-2.2.1.jar  
struts2-spring-plugin-2.2.1.jar  
xwork-core-2.2.1.jar 
分享到:
评论

相关推荐

    Spring3.0+myBatis3.0

    通过对这些文件的分析和学习,开发者可以深入了解Spring3.0与myBatis3.0的整合过程和具体实践。 总结,Spring3.0与myBatis3.0的整合,既发挥了Spring的高级特性,也利用了myBatis的灵活性,使得在处理数据访问时,...

    spring3.0 + mybatis源码

    当 Spring 3.0 与 MyBatis 结合使用时,通常会使用 Spring 的 DataSource、TransactionManager 和 SqlSessionFactoryBean 来管理数据源、事务以及 MyBatis 的会话工厂。这样可以实现数据库操作的事务管理,并且与 ...

    spring3.0 mybatis commons jar包

    5. **事务管理**:MyBatis可以与Spring框架无缝集成,提供事务控制。 **Spring与MyBatis整合** Spring 3.0与MyBatis的整合是常见的数据访问架构,主要步骤包括: 1. **添加依赖**:在项目中引入Spring和MyBatis的...

    Struts2+Spring3.0+MyBatis3.0平台搭建spring+json+gson+mysql,经典版本spring3.0+,完整架包

    此外,Spring3.0还集成了对其他技术的支持,如数据访问(JDBC、Hibernate、MyBatis)、Web应用(Spring MVC)、消息处理(JMS)等。 MyBatis3.0是一个轻量级的持久层框架,它将SQL语句与Java代码分离,使得开发者...

    Struts2+Spring3.0+MyBatis3.0

    在"Spring3.0和MyBatis3.0的集成"中,通常会使用Spring的DataSourceTransactionManager来管理事务,通过SqlSessionFactoryBean配置MyBatis的SqlSessionFactory,并通过MapperScannerConfigurer扫描Mapper接口,将...

    springMVC_spring3.0_mybatis2.1.1整合

    标题“springMVC_spring3.0_mybatis2.1.1整合”指的是将Spring MVC、Spring 3.0框架和MyBatis 2.1.1数据访问层进行集成的教程或项目示例。这个整合是Web开发中常见的技术栈组合,用于构建高效、灵活的Java Web应用。...

    spring3.0整合mybatis3.0、struts2

    本项目“spring3.0整合mybatis3.0、struts2”正是这样的一个尝试,旨在利用这三个主流的Java技术栈来搭建一个强大的后端架构。接下来,我们将详细探讨这三个框架各自的功能、整合的意义以及如何进行整合。 **Spring...

    struts2.0+spring3.0+mybatis3框架整合

    Struts2.0、Spring3.0和MyBatis3是Java Web开发中常见的三大框架,它们各自在应用程序的不同层次上发挥着重要作用。Struts2作为MVC(模型-视图-控制器)框架,主要负责处理请求和控制业务流程;Spring则是一个全面的...

    spring3.0 mvc+mybatis3.0

    标题 "spring3.0 mvc+mybatis3.0" 提到的是一个集成Spring MVC 3.0和MyBatis 3.0的项目实例,这两大框架在Java Web开发中占据重要地位。Spring MVC是Spring框架的一部分,专门用于构建Web应用程序的前端控制器,而...

    Myeclipse10搭建Flex4.6+spring3.0+mybatis3.2架构

    总结,这个例子展示了如何在Myeclipse10环境中集成Flex4.6、Spring3.0和(潜在的)Mybatis3.2,构建一个能够进行远程调用、处理数据和展示结果的完整应用程序。这样的架构是现代企业级应用的常见模式,能够充分利用...

    spring mvc 3.0-mybatis-freemarker整合

    在与Spring MVC集成时,MyBatis可以作为数据访问层,通过Spring的依赖注入机制,实现事务管理和数据库操作。 **Freemarker 2.3** Freemarker是一个开源的模板引擎,主要用于生成HTML或其他文本格式的输出。它允许...

    Struts2+Spring3+MyBatis框架整合源码+pdf整合文档

    在Spring中,MyBatis可以通过Spring的SqlSessionFactoryBean来配置,实现数据访问的事务管理和资源管理。 SSM整合的主要步骤包括: 1. **引入依赖**:在项目中添加Struts2、Spring3和MyBatis的相关jar包,以及它们...

    spring3.0+spring mvc3.0+mybaits3.0

    5. **与Spring的无缝集成**: 可以通过Spring的DataSource和TransactionManager配置,实现MyBatis的事务管理。 **整合过程** 整合Spring 3.0、Spring MVC 3.0和MyBatis 3.0,主要涉及以下步骤: 1. **配置Spring ...

    Spring3.0 chmAPI 和 Spring3.0所有jar 和 Spring3.0源码

    API文档还涵盖了Spring对其他技术如JDBC、Hibernate、MyBatis等的集成支持,有助于开发者快速理解和使用Spring3.0的各种组件。 **所有依赖的jar包** 这些jar包包含了Spring3.0运行所需的所有依赖,包括Spring的核心...

    Spring3.0中文帮助文档

    9. **测试支持**:Spring Test模块提供了对Spring应用程序的全面测试支持,包括单元测试和集成测试,可以方便地模拟IoC容器,测试Spring配置和组件。 10. **RESTful支持**:Spring 3.0引入了RestTemplate,使得开发...

    Spring3.0Jar包

    7. **数据访问增强**:Spring 3.0 对数据访问层进行了大量改进,包括对 JPA、Hibernate 和 MyBatis 等 ORM 框架的支持,以及对 NoSQL 数据库的集成,如 MongoDB。 8. **RESTful 支持**:通过 `@RequestMapping` ...

    Spring3.0中文版

    6. **数据访问**:Spring3.0对JDBC、Hibernate、MyBatis等持久层技术提供了更全面的支持,简化了数据库操作,如声明式事务管理。 7. **集成测试**:Spring Test模块提供了测试上下文的支持,使得单元测试和集成测试...

    spring3.0+ibatis 集成实例

    Spring 3.0 和 iBatis 的集成是一个常见的企业级应用开发模式,它结合了Spring的强大依赖注入(DI)和面向切面编程(AOP)能力与iBatis灵活的SQL映射机制,实现了业务逻辑层与数据访问层的分离,提高了代码的可维护...

    spring3.0jar包集合

    Spring 3.0提供了对多种数据访问技术的集成,包括JDBC、Hibernate、MyBatis等ORM框架,使得数据库操作更加简单和灵活。此外,Spring的事务管理功能可以在不同数据访问技术之间提供一致的事务策略。 5. **批注驱动...

Global site tag (gtag.js) - Google Analytics