- 浏览: 419617 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (71)
- spring-->>备忘笔记 (17)
- struts-->>备忘笔记 (4)
- hibernate-->>备忘笔记 (6)
- J2EE (10)
- linux (4)
- AOP (3)
- ibatis (1)
- bean (1)
- scop (1)
- IOC (2)
- Central Authentication Service (5)
- javascript-->>备忘笔记 (12)
- 程序人生 (2)
- MongoDB-->>备忘笔记 (2)
- java-->>静态与非静态语句块 (1)
- java-->>泛型 (1)
- java-->>线程 (4)
- java-->>堆栈 (1)
- java-->>jvm (1)
- java-->>工具类 (3)
- mysql-->>备忘笔记 (2)
- 设计模式-->>备忘笔记 (1)
- oracle-->>备忘笔记 (0)
- 互联网->>电子商务 (5)
最新评论
-
lihaiming:
shengouqiang 写道例如有两个线程同时执行(没有sy ...
java之yield(),sleep(),wait()区别详解-备忘笔记 -
zjxchase:
你的onlyMoney这个方法好像不太好用
js 之 Number 工具类 -
shengouqiang:
例如有两个线程同时执行(没有synchronized)一个线程 ...
java之yield(),sleep(),wait()区别详解-备忘笔记 -
u011028234:
楼主你这例子里边的SampleResource实体没有额?
spring 控制反转与依赖注入原理-学习笔记 -
yueerba:
[flash=200,200][url][url][img][ ...
spring 控制反转与依赖注入原理-学习笔记
声明式事务管理:
Spring提供了声明式事务管理。是通过Spring AOP实现的。
Spring中进行事务管理的通常方式是利用AOP(面向切片编程)的方式,为普通java类封装事务控制,它是通过动态代理实现的,由于接口是延迟实例化的,spring的在这段时间内通过拦截器,加载事务切片。原理就是这样的,可以参考JDK动态代理实例。
Spring中进行事务控制:
动态代理的一个重要特征是,它是针对接口的,所以我们的DAO要通过动态代理来让spring接管事务,就必须在dao前面抽象出一个接口,当然如果没有这样的接口,那么spring会使用CGLIB来决解问题,但这不是spring推荐的方式。
大多数spring用户选择声明式事务管理。这是最少影响应用代码的选择,因而这是和非侵入性的轻量级容器的观念是一致的。
从考虑EJB CMT和spring声明式事务管理的相似以及不同之处出发是很有益的。他们的基本方法是相似的:都可以指定事务管理到单独的方法;如果需要可以在事务上下文调用setRollbackOnly()方法。不同之处如下:
1、不像EJB CMT绑定在JTA上,spring声明式事务管理可以在任何环境下使用。只需要更改配置文件,它就可以和JDBC、JDO、Hibernate或其他的事务机制一起工作。
2、spring可以使声明式事务管理应用到普通的Java对象,不仅仅是特殊的类,如EJB。
3、spring提供声明式回滚规则:EJB诶呦地域的特征,回滚可以声明式控制,不仅仅是编程式的。
4、spring允许你通过AOP定制事务行为。如:如果需要,可以在事务回滚中插入定制的行为。也可以增加任意的通知,就像事务通知一样。使用EJB CMT,除了使用setRollbackOnly(),你没有办法能够影响容器的事务管理。
5、spring不提供高端应用服务器的跨越远程调用的事务上下文传播。如果你需要这些特征,推荐你使用EJB。然而,不要轻易使用这些特性。通常我们并不希望事务跨越远程调用。
回滚规则的概念:他们使得我们可以指定哪些异常应该发起自动回滚。我们在配置文件中,而不是Java代码中,以声明的方式指定。因此,虽然我们仍然可以编程调用TransactionStatus对象的setRollbackOnly()方法来回滚当前事务,多数时候我们可以指定规则,如MyApplicationException应用导致回滚。这有明显的优点,业务对象不需要依赖事务基础设施。例如:通常不需要引入任何Spring API,事务或其他任何东西。
EJB的默认行为是遇到系统异常(通常是运行是异常),EJB容器自动回滚事务。EJB CMT遇到应用程序异常(除了java.rmi.RemoteExcepiton外的checked异常)是不需要自动回滚事务。虽然Spring声明式事务管理沿用EJB的约定(遇到unchecked异常自动回滚事务),但是这是可以定制的。
Spring声明式事务管理的性能要胜过EJB CMT。
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd"> <!-- 配置数据库驱动 --> <!-- <context:property-placeholder location="classpath:jdbc.properties"/> --> <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="locations"> <list> <value>classpath:init.properties</value> </list> </property> </bean> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${datasource.driverClassName}"/> <property name="url" value="${datasource.url}"/> <property name="username" value="${datasource.username}"/> <property name="password" value="${datasource.password}"/> <!-- 连接池启动是的初始值 --> <property name="initialSize" value="${datasource.initialSize}"/> <!-- 连接池的最大值 --> <property name="maxActive" value="${datasource.maxActive}"/> <!-- 最大空闲值、当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 --> <property name="maxIdle" value="${datasource.maxIdle}"/> <!-- 最小空闲值,当空闲的连接数少于阀值时,连接池就会预申请去一些连接、以免洪峰来时来不及申请 --> <property name="minIdle" value="${datasource.minIdle}"/> </bean> <!-- 配置hibernateSessionFactory --> <bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- <property name="mappingResources"> <list> <value>com/sample/domain/Person.hbm.xml</value> </list> </property> --> <property name="mappingDirectoryLocations"> <list> <!-- 采用属性注入com/sample/domain包下所有hbm.xml加载进来 --> <value>classpath:com/sample/admin/domain</value> </list> </property> <property name="hibernateProperties"> <value> hibernate.dialect=${hibernate.dialect} hibernate.hbm2ddl.auto=${hibernate.hbm2ddl.auto} hibernate.show_sql=${hibernate.show_sql} hibernate.format_sql=${hibernate.format_sql} hibernate.cache.use_second_level_cache=${hibernate.cache.use_second_level_cache} hibernate.cache.use_query_cache=${hibernate.cache.use_query_cache} hibernate.cache.provider_class=${hibernate.cache.provider_class} </value> <!-- 另外一种写法 --> <!-- <props> <prop key="hibernate.dialect">${hibernate.dialect}</prop> </props> --> </property> </bean> <!-- 配置事务管理器 --> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <!-- 延时加载问题解决OpenSessionInViewInterceptor 和 OpenSessionInViewFilter的配置 在没有使用Spring提供的Open Session In View情况下,因需要在service(or Dao)层里把session关闭, 所以lazy loading 为true的话,要在应用层内把关系集合都初始化, 如 company.getEmployees(),否则Hibernate抛session already closed Exception --> <bean name="openSessionInViewInterceptor" class="org.springframework.orm.hibernate3.support.OpenSessionInViewInterceptor"> <property name="sessionFactory"> <ref bean="sessionFactory"/> </property> </bean> <bean id="urlMapping" class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping"> <property name="interceptors"> <list> <ref bean="openSessionInViewInterceptor"/> </list> </property> </bean> <!-- 事务策略配置管理器 PROPAGATION_REQUIRED:支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。spring默认的事务策略 PROPAGATION_SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行。 PROPAGATION_MANDATORY:支持当前事务,如果当前没有事务,就抛出异常。 PROPAGATION_REQUIRES_NEW:新建事务,如果当前存在事务,把当前事务挂起。 PROPAGATION_NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。 PROPAGATION_NEVER:以非事务方式执行,如果当前存在事务,则抛出异常。 PROPAGATION_NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。 -Exception表示有Exception抛出时,事务回滚. -代表回滚+就代表提交 readonly 就是read only, 设置操作权限为只读,一般用于查询的方法,优化作用. 设置强制使用CGLIB生成代理(spring代理方式 另外一种 JDKProxy动态代理) <property name="optimize" value="true" /> --> <!-- <bean id="baseTransaction" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" abstract="true"> <property name="transactionManager" ref="transactionManager" /> <property name="proxyTargetClass" value="true"/> <property name="transactionAttributes"> <props> <prop key="get*">PROPAGATION_NOT_SUPPORTED,readOnly</prop> <prop key="find*">PROPAGATION_NOT_SUPPORTED,readOnly</prop> <prop key="load*">PROPAGATION_REQUIRED,readOnly</prop> <prop key="query*">PROPAGATION_REQUIRED,readOnly</prop> <prop key="read*">PROPAGATION_REQUIRED,readOnly</prop> <prop key="save*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="add*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="create*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="update*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="modify*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="change*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="delete*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="remove*">PROPAGATION_REQUIRED,-Exception</prop> <prop key="*">PROPAGATION_REQUIRED,-Exception</prop> </props> </property> <property name="optimize" value="true" /> </bean> --> <!-- 采用AOP拦截的方式实现事务管理 --> <aop:config proxy-target-class="true"> <aop:pointcut id="transacationPointcut" expression="execution(* com.sample.admin.service..*.*(..))"/> <aop:advisor advice-ref="txAdvisor" pointcut-ref="transacationPointcut"/> </aop:config> <tx:advice id="txAdvisor" transaction-manager="transactionManager"> <tx:attributes> <tx:method name="get*" read-only="true" propagation="NOT_SUPPORTED"/> <tx:method name="find*" read-only="true" propagation="NOT_SUPPORTED"/> <tx:method name="query*" read-only="true" propagation="NOT_SUPPORTED"/> <tx:method name="read*" read-only="true" propagation="NOT_SUPPORTED"/> <tx:method name="load*" read-only="true" propagation="REQUIRED"/> <tx:method name="save*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="add*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="create*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="update*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="modify*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="change*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="delete*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="remove*" propagation="REQUIRED" rollback-for="Exception"/> <tx:method name="*" propagation="REQUIRED" rollback-for="Exception"/> </tx:attributes> </tx:advice> <!-- 采用注解方式配置 打开 --> <!-- <tx:annotation-driven transaction-manager="transactionManager" />--> </beans>
发表评论
-
[spring]事务传播级别隔离级别以及高并发下的应用经验
2012-02-12 01:06 10099事务是逻辑处理原子 ... -
spring中的@Transaction配置详解-学习笔记
2011-12-16 17:42 21390spring中的@Transaction配置详解 1、 ... -
spring AspectJ的Execution表达式-备忘笔记
2011-12-16 23:57 14081Aspectj切入点语法定义 在使用spring框 ... -
spring 配置文件实现AOP-学习笔记
2011-12-15 16:15 1609Spring 对AOP的支持I: Aspect默认情况 ... -
spring JDK的Proxy技术实现AOP功能和CGBLB-学习笔记
2011-12-15 16:05 1875动态代理类(以下简称为代理类)是一个实现在创建类时在运行时指定 ... -
spring容器自动扫面管理bean-学习笔记
2011-12-15 16:42 1556通过在classpath自动扫描方式把组件纳入sp ... -
spring自动装配注解模式-学习笔记
2011-12-15 16:43 3436spring 自动装配注解模式 1、什么是自动装配 ... -
spring的注入依赖之构造器注入- 学习笔记
2011-12-15 16:44 2189Spring的注入依赖(DI)主要有三种注入方式, ... -
spring 控制反转与依赖注入原理-学习笔记
2011-12-14 22:24 11806在Spring中有两个非常 ... -
spring Bean的作用域scope-学习笔记
2011-12-14 22:09 1851Spring容器最初提供了 ... -
添加xml文件自动提示方法,以spring配置文件为例-备忘录
2011-12-14 22:01 1085用eclipse,在导入相应的包后(有人说不导包也有提示,因为 ... -
基于Struts、Hibernate、Spring 的学习框架-笔记备忘
2011-12-13 20:24 1172基于Struts、Hibernate、Spring 的学 ... -
spring声明式事务策略 aop拦截-学习笔记
2011-12-13 20:20 1543声明式事务管理: Spring提供了声明式事务管理 ... -
三种实例化Spring中Bean对象的方式
2011-12-13 20:17 16681、使用类构造器实例化。 <!-- 使用类构造器实 ... -
spring中的@Transaction配置详解
2011-12-13 20:13 7978spring中的@Transaction配 ... -
SSH整合包详解.Struts2.2.3+Spring3.1.0.M2+Hibernate3.6.6-学习笔记
2011-12-13 20:33 1763SSH整合包详解: a) commons commo ...
相关推荐
Spring事务的实现方式主要有编程式事务管理和声明式事务管理。编程式事务需要编写代码来管理事务边界,而声明式事务则通过XML配置或注解方式将事务管理与业务逻辑分离。Spring框架的事务管理有其优点,如统一的事务...
本资料“Spring学习笔记&源码”是基于网易云课堂黑马程序员的Spring四天精通课程,旨在帮助学习者深入理解和实践Spring框架。 笔记部分可能会涵盖以下内容: 1. **Spring概述**:介绍Spring框架的历史、特点和主要...
这部分内容会涉及到事务管理,如编程式和声明式事务,以及如何通过Spring Data简化数据库操作。 最后,Spring Boot是近年来非常流行的快速开发工具,它集成了大量Spring生态系统的组件,并提供了自动配置功能,极大...
Spring AOP提供了@Transactional注解,可以方便地进行声明式事务管理。只需在服务层的方法上添加该注解,Spring就会自动进行事务的开启、提交或回滚。例如: ```java @Service public class UserService { @...
- **事务管理**:Spring提供了声明式和编程式的事务管理,可以方便地进行事务控制。 - **MVC框架**:Spring MVC提供了一种优雅的方式处理HTTP请求,模板引擎和视图解析,以及强大的模型绑定和数据验证功能。 - **...
2. 事务管理:Spring提供了一种声明式事务管理方式,无需编写复杂的事务传播代码。 3. 单例模式:Spring默认会将bean设置为单例模式,确保在整个应用中只有一个实例。 4. AOP支持:Spring的面向切面编程允许开发者...
3. **事务管理**:Spring提供了声明式事务管理,可以跨越多个DAO操作,确保数据的一致性。 4. **Action和Service层**:Struts2的Action对象通常只负责接收请求和转发到相应的Service方法,业务逻辑在Service层处理,...
-声明式事务管理:通过@Transactional注解在方法上声明事务边界。 以上就是Spring框架的一些基础知识点,从入门到精通,需要不断学习和实践,逐步掌握其精髓。通过Spring教程和笔记,你可以深入理解并运用这些知识...
3. **事务管理**:Spring 提供的声明式事务管理可以无缝集成到Struts应用中,简化了事务控制的复杂性。 在提供的"spring+struts集成学习笔记和项目源码"中,你将有机会深入理解这些概念,通过实际操作来学习如何将...
- **AspectJ**:一种强大的AOP框架,支持声明式的切面编程。 - **专业术语**: - **Aspect**:定义了一个切面。 - **Join Point**:程序执行过程中的某个特定点。 - **Pointcut**:匹配Join Point的表达式。 - ...
6. **事务管理**: 提供编程和声明式事务管理,与Spring整合时通常使用声明式事务。 **Spring3笔记** Spring是企业级应用的全面解决方案,包括依赖注入(DI)、面向切面编程(AOP)、事务管理等。以下是关键点: 1...
同时,可能还会探讨Spring的事务管理,包括编程式和声明式事务,以及如何在业务逻辑中实现事务的回滚和提交。 day03可能会转向Spring MVC,这是Spring框架中用于构建Web应用程序的一部分。这部分内容可能涵盖模型-...
Spring的声明式事务管理让开发者无需手动编写事务代码,提高了代码的可读性和可维护性。 **Hibernate框架** Hibernate是一个强大的ORM(Object-Relational Mapping,对象关系映射)框架,它将Java对象与数据库中的...
1. Spring声明式事务管理的工作原理。 2. 如何在Spring中配置Hibernate事务管理。 3. `@Transactional`注解的使用及其属性含义。 4. 如何处理事务的异常和回滚规则。 5. 实现Spring和Hibernate的无缝集成,提升代码...
此外,我们可能还会讨论到Spring的事务管理,了解如何使用@Transactional注解实现声明式事务处理。 总的来说,Spring培训的第四天将带你深入理解Spring框架的核心技术,包括DI、AOP和Spring MVC,这些都是Spring...
- **Spring的事务管理**:熟悉编程式和声明式事务管理,以及如何在Spring中配置事务边界。 - **Spring整合Hibernate**:学习如何将Hibernate集成到Spring应用中,利用Spring的数据访问抽象层(如HibernateTemplate或...
AOP 通过切面(Aspect)和通知(Advice)来定义关注点的分离,提供了声明式事务管理,使得事务管理变得简单且易于维护。 4.6 持久化支持 Spring 提供了对各种持久化技术的支持,包括 JDBC、JPA、Hibernate 等。...
Spring 2.x版本引入了许多新特性,比如改进的AOP支持、增强的声明式事务管理等。 #### Annotation(Spring高版本) 随着Spring的发展,注解成为了配置Spring应用的主要方式。Spring 3引入了大量的新注解,如`@...