- 浏览: 446432 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (267)
- java (8)
- 求职&面试 (1)
- linux (33)
- windows (1)
- C++ (5)
- android (12)
- QT (1)
- 经验 (1)
- memory-leaks (1)
- Streaming&V/A (1)
- network&security (5)
- SCM (13)
- mysql (10)
- browsers (4)
- Windows APIs (2)
- opensource (1)
- pm (1)
- GDI (1)
- database (14)
- MFC (1)
- web&fronts (17)
- Tomcat (4)
- OLE (1)
- 观后感 (1)
- Production (2)
- UML (3)
- Javascript (7)
- Cloud Computing&SAAS (5)
- SoftwareEngineering (1)
- Computer&Maintenance (1)
- Web (8)
- Desgin (1)
- J2ee (10)
- mysql cluster (0)
- LB&HA (2)
- webserver (11)
- php (5)
- cas&authtication (0)
- Languages (1)
- IDEs (3)
- architecture (2)
- iOS (8)
- spring (3)
- webservices (1)
- security (1)
- MVCFrameworks (2)
- bservices (0)
- build-tools (2)
- unittest (1)
- spring-security (0)
- sphinx (2)
- hibernate (1)
- mybatis (2)
- search (0)
- nginx (2)
- design&production (2)
- DFS (0)
- algorithm (0)
- distributed&network (0)
- blogs (0)
- os&admin (0)
- fastcgi (0)
- kv-db (0)
- operation&maintenance (1)
- productions (9)
- 养生 (1)
- appserver (1)
- HTTP (2)
- test (1)
- erlang (2)
- browser (0)
- 非技术 (2)
- mobiles (2)
- cloud computing (2)
- Business (2)
- maven (1)
- python (5)
- 人生 (0)
- Cryptography (3)
- CV (0)
- cms (2)
- jqm (2)
- html (2)
- flex (1)
- redmine (1)
- iptables (1)
- groovy (1)
- scala (1)
- grails (1)
- ftp (3)
- vsftpd (2)
- lua (0)
- chroot (3)
- jailkit (3)
- UED (0)
- myeclipse (2)
- ide (2)
- eclipse (2)
最新评论
-
Nick712:
http://blog.csdn.net/victory08/ ...
处理SVN出现:Cleanup failed to process the following paths: xxx -
xs6262460:
Spring AOP根据JdbcTemplate方法名动态设置数据源 -
xhpscdx:
我的解决办法是把D:\ACRS\Projects\TAIS 下 ...
处理SVN出现:Cleanup failed to process the following paths: xxx -
hnraysir:
总结得相当不错,支持下。
使用CodeIgniter 创建 RESTful 服务 REST API【原创译文】 -
云上太阳:
这个必须评论下,间接的救过俺的命啊
解决tomcat启动报错,加强错误日志的显示:
采用的基本搭建环境:SpringMVC、MyBatis、MySQL、tomcat
Spring事务管理分解了传统的全局事务管理和本地事务管理的劣势,使得在任何环境中都可以使用统一的事务管理模型,你可以写一次代码,然后在不同的环境从你的代码里面配置不同的事务管理策略,Spring提供两种事务管理策略:一种是声明式事务管理策略,另一种是编程式事务管理策略,这里主要介绍声明式事务管理策略
由于采用的是SpringMVC、 MyBatis,故统一采用了标注来声明Service、Controller
由于服务器启动时的加载配置文件的顺序为web.xml---root-context.xml(Spring的配置文件)---servlet-context.xml(SpringMVC的配置文件),由于root-context.xml配置文件中Controller会先进行扫描装配,但是此时service还没有进行事务增强处理,得到的将是原样的Service(没有经过事务加强处理,故而没有事务处理能力),所以我们必须在root-context.xml中不扫描Controller,配置如下:
在servlet-context.xml中扫描Controller同时不扫描Service,配置如下:
下面就可以进行配置声明式事务管理了,配置如下:
到此我的配置完成了,但是经过我的测试,当我往MySQL数据库表批量增加对象时,当其中一个对象出现错误,抛出CustomException事务却不回滚,这个真是令人头疼,于是我继续查找,步骤如下:
1. 查找是否声明式事务管理有误,如切入点写错了
2. 查找Controller扫描部分配置是否正确
但是这两点我都查了,还是事务没有回滚,这个时候我没办法了,只能动用终极武器了:查看源码,开始debug程序,发现进入到了事务,并且出现了异常,捕获后进入到了回滚程序,但是数据库却没有回滚,为了避免Spring自己的AbstractPlatformTransactionManager的干扰,我自己定制了一个事务管理类并继承配置文件中的DataSourceTransactionManager类,这样可以清楚的看到程序的运行轨迹,继续DEBUG,还是出现了异常,捕获后进入到了回滚程序,但是数据库却没有回滚,此刻我开始怀疑MySQL数据库的事务支持功能了,于是网上查找MySQL对事务的支持,发现MySQL4.0以后可以支持事务,但是MySql的数据表分为两类,一类是传统的数据表,另一类则是支持事务的数据表。支持事务的数据表分为两种:InnoDB和BerkeleyDB
使用一下命令:show create table *** 查看我的数据库表的属性才发现我的表原来是传统类型的表,于是我使用navicat更改了表的类型为:InnoDB,然后运行程序发现事务回滚了
到此SpringMVC声明式事务管理配置完成,并运行正确
Spring事务管理分解了传统的全局事务管理和本地事务管理的劣势,使得在任何环境中都可以使用统一的事务管理模型,你可以写一次代码,然后在不同的环境从你的代码里面配置不同的事务管理策略,Spring提供两种事务管理策略:一种是声明式事务管理策略,另一种是编程式事务管理策略,这里主要介绍声明式事务管理策略
由于采用的是SpringMVC、 MyBatis,故统一采用了标注来声明Service、Controller
由于服务器启动时的加载配置文件的顺序为web.xml---root-context.xml(Spring的配置文件)---servlet-context.xml(SpringMVC的配置文件),由于root-context.xml配置文件中Controller会先进行扫描装配,但是此时service还没有进行事务增强处理,得到的将是原样的Service(没有经过事务加强处理,故而没有事务处理能力),所以我们必须在root-context.xml中不扫描Controller,配置如下:
- <!-- 自动扫描组件,这里要把controler下面的 controller去除,他们是在spring3-servlet.xml中配置的,如果不去除会影响事务管理的。 -->
- <context:component-scan base-package="com.sence">
- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
- </context:component-scan>
在servlet-context.xml中扫描Controller同时不扫描Service,配置如下:
- <!-- 扫描所有的controller 但是不扫描service-->
- <context:component-scan base-package="com.sence">
- <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service" />
- </context:component-scan>
下面就可以进行配置声明式事务管理了,配置如下:
- <!-- transaction manager, use DataSourceTransactionManager -->
- <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
- <property name="dataSource" ref="dataSource" />
- </bean>
- <!-- spring declarative transaction management -->
- <aop:config>
- <aop:pointcut id="fooServiceMethods"
- expression="execution(* com.sence.*.service.impl.*.*(..))"/>
- <aop:advisor advice-ref="txAdvice" pointcut-ref="fooServiceMethods"/>
- </aop:config>
- <tx:advice id="txAdvice" transaction-manager="txManager">
- <tx:attributes>
- <tx:method name="find*" read-only="true"/>
- <tx:method name="load*" read-only="true"/>
- <tx:method name="*" rollback-for="CustomException"/>
- </tx:attributes>
- </tx:advice>
到此我的配置完成了,但是经过我的测试,当我往MySQL数据库表批量增加对象时,当其中一个对象出现错误,抛出CustomException事务却不回滚,这个真是令人头疼,于是我继续查找,步骤如下:
1. 查找是否声明式事务管理有误,如切入点写错了
2. 查找Controller扫描部分配置是否正确
但是这两点我都查了,还是事务没有回滚,这个时候我没办法了,只能动用终极武器了:查看源码,开始debug程序,发现进入到了事务,并且出现了异常,捕获后进入到了回滚程序,但是数据库却没有回滚,为了避免Spring自己的AbstractPlatformTransactionManager的干扰,我自己定制了一个事务管理类并继承配置文件中的DataSourceTransactionManager类,这样可以清楚的看到程序的运行轨迹,继续DEBUG,还是出现了异常,捕获后进入到了回滚程序,但是数据库却没有回滚,此刻我开始怀疑MySQL数据库的事务支持功能了,于是网上查找MySQL对事务的支持,发现MySQL4.0以后可以支持事务,但是MySql的数据表分为两类,一类是传统的数据表,另一类则是支持事务的数据表。支持事务的数据表分为两种:InnoDB和BerkeleyDB
使用一下命令:show create table *** 查看我的数据库表的属性才发现我的表原来是传统类型的表,于是我使用navicat更改了表的类型为:InnoDB,然后运行程序发现事务回滚了
到此SpringMVC声明式事务管理配置完成,并运行正确
发表评论
-
iBATIS In Action:使用高级查询技术(一)
2013-06-15 16:04 966iBATIS In Action:使用高级 ... -
hibernate+spring 注解 对事务的一些信息
2012-10-23 00:33 886hibernate+spring 注解 对事务的一些信息 ... -
Spring 事务配置方法二则
2012-10-23 00:06 947Spring 事务配置方法二则 第一种配置 ... -
Spring事务配置的五种方式
2012-10-23 00:04 759Spring事务配置的五种方式 前段时间对Sp ... -
Log4j使用总结
2012-09-26 19:18 850Log4j使用总结 一、介绍 Log4 ... -
Spring中的ContextLoaderListener作用
2012-09-23 13:12 0Spring中的ContextLoaderListe ... -
PO BO VO DTO POJO DAO概念
2012-09-21 16:28 958PO BO VO DTO POJO DAO概 ... -
Spring Jar包详解
2012-09-19 20:14 894Spring Jar包详解 spr ... -
spring事务的annotation-driven用法
2012-09-06 00:23 0spring事务的annotation-drive ... -
结合Spring使用Mybatis Generator生成的代码
2012-09-05 23:26 0结合Spring使用Mybatis Generato ... -
JPetStore项目分析——分析一个典型J2EE应用web层的实现
2012-09-05 11:18 0J PetStore项目分析——分析一个典型J2EE应 ... -
在Hibernate里面动态切换SChema实现访问不同的数据库的几种方法
2012-08-23 10:26 1201在Hibernate里面动态切换SChema实现访问 ... -
Spring AOP根据JdbcTemplate方法名动态设置数据源
2012-08-23 10:05 8625Spring AOP根据JdbcTemplate方 ... -
基于 Spring 和 iBATIS 的动态可更新多数据源持久层
2012-08-20 14:45 0我们时常会遇到一些 web 项目,需要从不同的数据源中抓 ... -
Spring下 mybatis 多数据源配置
2012-08-20 14:00 1251本文非原创! Spring下 myb ...
相关推荐
在IT行业中,SpringMVC、MyBatis以及声明式事务管理是Java Web开发中的关键组件。这个项目结合了这三个核心技术,构建了一个高效、稳定的后端系统。以下将详细阐述这些技术及其相互配合的工作原理。 首先,...
本文将详细讲解如何在SpringMVC与MyBatis结合的项目中实现声明式事务管理。 首先,我们了解声明式事务管理的基本概念。这种管理方式是通过在服务层方法或控制器层方法上添加特定注解(如@Transactional)来声明事务...
2. **灵活的事务管理**:Spring提供了声明式事务管理,可以在SpringMVC和Mybatis之间无缝协调事务,确保数据一致性。 3. **方便的控制器层**:SpringMVC的控制器使得HTTP请求的处理变得简单,同时可以利用Spring的...
声明式事务管理是通过在配置文件或注解中定义事务边界来实现的。在SpringMVC+MyBatis的应用中,通常会在Service层方法上添加@Transactional注解,指定事务属性如隔离级别、传播行为等。当方法执行过程中出现异常时...
3. **事务管理**:Spring支持声明式和编程式的事务管理,简化了事务处理。 **SSM整合** 在SSM框架中,Spring作为基础,负责整体的依赖管理和事务控制;SpringMVC处理HTTP请求,与前端交互;MyBatis则作为数据访问层...
MyBatis是一个优秀的持久层框架,它简化了JDBC的复杂性,允许开发者编写声明式的SQL映射代码。MyBatis的核心是XML或注解形式的映射文件,其中定义了SQL语句、参数映射和结果映射。通过这种方式,MyBatis可以将Java...
它的核心理念是简化企业级应用开发,通过提供全面的基础设施支持,减少了编码量,增强了应用的可测试性,并且支持声明式事务管理等企业级功能。Spring的核心特性包括依赖注入(DI)、面向切面编程(AOP)、事件传播...
5. 数据源和事务管理:配置数据源(如Druid或HikariCP),并使用Spring的声明式事务管理。 6. 创建Controller:编写SpringMVC的Controller类,定义处理HTTP请求的方法。 7. 编写Service和DAO:根据业务需求,编写...
5. **事务管理**:Spring的声明式事务管理可能被用来处理数据库操作的事务,确保数据的一致性。 6. **测试支持**:Maven通常会包含测试相关的配置,如JUnit或Mockito,用于单元测试和集成测试,保证代码质量。 7. ...
- SpringMVC与MyBatis整合后,Spring可以提供声明式事务管理。在配置文件中定义事务管理器,通过@Transactional注解标记在需要事务控制的方法上。 - 事务的隔离级别、回滚规则等都可以在配置文件中设定。 6. **...
而@Transactional注解则用于声明式事务管理,确保数据的一致性。 3. MyBatis MyBatis是一个持久层框架,它将SQL语句与Java代码分离,提供了动态SQL的功能。MyBatis通过Mapper接口和XML或注解方式定义SQL,实现了SQL...
Spring MVC提供了一种声明式异常处理机制,支持多种视图技术如JSP、FreeMarker等,并且可以与Spring其他模块(如Spring AOP、Spring Security)无缝集成。 MyBatis是一个轻量级的持久层框架,它将SQL语句直接写在...
Spring提供了一种声明式事务管理方式,通过在方法上添加@Transactional注解,可以自动管理事务的开始、提交、回滚。如果方法执行过程中发生异常,Spring会自动回滚事务;如果没有异常,则在方法结束后提交事务。这种...
SpringMVC+MyBatis的事务管理可以使用编程式事务管理和声明式事务管理两种方式。声明式事务管理可以将事务管理和业务逻辑分离,提高代码的可读性和维护性。同时,MyBatis的事务管理机制可以和Spring的事务管理集成,...
核心特性包括依赖注入(DI)、面向切面编程(AOP)以及声明式事务管理。 1. **依赖注入(DI)**:允许开发者在运行时通过容器来管理对象及其依赖关系,减少了代码间的耦合,提高了可测试性和可维护性。 2. **面向切...
Spring框架提供了SpringMVC和Mybatis的整合方式,如使用Spring的声明式事务管理,可以在Spring配置中统一管理事务的开始、提交、回滚。同时,Spring还可以通过@Autowired注解自动注入Mybatis的Mapper接口,简化了...
2. **事务管理**:Spring提供了声明式事务管理,通过`@Transactional`注解,可以在方法级别控制事务的开始、提交、回滚,简化了事务处理。 3. **Mapper接口**:在Spring MVC中,可以使用MyBatis的Mapper接口,通过...
- 事务管理:Spring提供的声明式事务管理可以方便地控制事务边界。 - 测试友好:通过Spring的依赖注入,可以轻松地进行单元测试和集成测试。 通过以上整合,开发者可以在SpringMVC的Web环境中轻松地使用MyBatis...
MyBatis与Spring框架结合使用时,可以实现声明式和编程式的事务管理。 项目中可能包含的文件结构和关键组件: - `pom.xml`:Maven的项目对象模型文件,定义了项目依赖和构建设置。 - `src/main/java`:Java源代码...
- **事务管理**:Spring提供声明式事务管理,可以在配置文件中声明事务边界。 3. **Mybatis**: - **简介**:Mybatis是一个轻量级的持久层框架,它简化了SQL操作,将SQL与Java代码分离。 - **配置**:Mybatis的...