spring事物管理

Wesley13
• 阅读 354

Spring提供了一流的事务管理。在Spring中可以支持声明式事务和编程式事务

spring事物的概念和重要性
事物的属性
事物管理器
声明事物

1.1
定义:
事务管理在应用程序中起着至关重要的作用:它是一系列任务的组成工作单元,在这个工作单元中,所有的任务必须同时执行。它们只有二种可能执行结果,要么所有任务全部执行成功,要么所有任务全部执行失败。
其优点如下:

为不同的事务的API提供一致的编程模式
提供更简单,更易地使用的编程式事务管理
支持Spring声明事务
整合Spring对数据访问的抽像

1.2
事物的四大特性:
原子性:

  • 事务结束的时候,事务中的所有任务必须全部成功完成,否则全部失败,事务回滚到事务开始之间的状态。

一致性:

  • 即数据库中的所有数据和现实保持一致。如果事务失败数据必须返回到事务执行之前的状态,反之修改数据和现实的同步。

隔离性:

  • 每个事务必须与其他事务的执行结果隔离开,直到该事务执行完毕,它保证了事务的访问的任何数据不会受其他事务执行结果的影响

持久性:

  • 如果事务成功执行,无论系统发生任何情况,事务的持久性都必须保证事务的执行结果是永久的。

1.3
事物的传播行为(7种):
*PROPAGATION_MANDATORY:
规定了方法必须在事务中运行,否则会抛出异常

*PROPAGATION_NESTED:
使方法运行在嵌套事务中,否则这个属性和PROPAGATION_REQUIRED属性的义相同

PROPAGATION_NEVER
使当前方法永远不在事务中运行,否则抛出异常

PROPAGATION_NOT_SUPPORTED
定义为当前事务不支持的方法,在该方法运行期间正在运行的事务会被暂停

*PROPAGATION_REQUIRED
规定当前的方法必须在事务中,如果没有事务就创建一个新事务,一个新事务和方法一同开始,随着方法的返回或抛出异常而终止

*PROPAGATION_REQUIRED_NEW
当前方法必须创建新的事务来运行,如果现存的事务正在运行就暂停它

PROPAGATION_SUPPORTS
规定当前方法支持当前事务处理,但如果没有事务在运行就使用非事务方法执行

例如:


PROPAGATION_REQUIRED,timeout_5,readOnly
PROPAGATION_REQUIRED
PROPAGATION_REQUIRED


1.4
事物的隔离级别:
ISOLATION_DEFAULT
使用数据库默认的隔离级别
ISOLATION_COMMITTED
大多数主流数据库的默认Spring事务隔离等级,保证了一个事务不会读到另一个并行事务已修改但未提交的数据,避免了“脏读取”。该级别适用于大多数系统。
ISOLATION_READ_UNCOMMITTED
保证了读取过程中不会读取到非法数据。Spring事务隔离级别在于处理多事务的并发问题,这是速度最 快的一个隔离级别,但同时它的隔离级别也是最低
ISOLATION_REPEATABLE_READ
保证了一个事务不会修改已经由另一个事务读取但未提交(回滚)的数据。避免了“脏读取”和“不可重复读取”的情况,但是带来了更多的性能损失
ISOLATION_SERIALIZABLE
这是最高的隔离级别,它可以防此脏读,不可重复读和幻读等问题,但因其侵占式的数据记录完全锁定,导致它影响事务的性能,成为隔离级别中最展慢的一个。
注意:并不是所有的资源管理器都支持所有的隔离级别,可针对不同的资源管理使用以上的隔离级别。
1.5
事物的只读属性:
如果将事务声明为只读的,那么数据库可以根据事务的特性优化事务的读取操作。事务的只读属性需要配合事务的传播行为共同设置。例如:
PROPAGATION_REQUIRED,readOnly
事物的超时属性:
通过设置事务的超时时间,从开始执行事务起,在规定的超时时间内如果没有事务就将它回滚。事务的超时属性以timeout_为前缀和一个整型数字定义,例如:
PROPAGATION_REGUIRED,timeout_5,readOnly
1.6
事务管理器:
Spring的事务管理器有5个,都实现了PlatformTransactionManager接口,如下所示:

DataSourceTransactionManager           JDBC事务管理器
HibernateTransactionManager            Hibernate事务管理器
JdoTransactionManager                  JDO事务管理器
JtaTransactionManager                   JTA事务管理器
PersistenceBrokerTransactionManager    Apache的OJB事务管理器









tarena/hbm/catelog.hbm.xml
tarena/hbm/bookinfo.hbm.xml
tarena/hbm/userinfo.hbm.xml
tarena/hbm/order.hbm.xml





org.hibernate.dialect.MySQL5Dialect


true 'Y', false 'N'

true




spring事物配置的详情和多种方式,请参考

http://jackjobs.iteye.com/blog/1697145

点赞
收藏
评论区
推荐文章
浅梦一笑 浅梦一笑
5个月前
初学 Python 需要安装哪些软件?超级实用,小白必看!
编程这个东西是真的奇妙。对于懂得的人来说,会觉得这个工具是多么的好用、有趣,而对于小白来说,就如同大山一样。其实这个都可以理解,大家都是这样过来的。那么接下来就说一下python相关的东西吧,并说一下我对编程的理解。本人也是小白一名,如有不对的地方,还请各位大神指出01名词解释:如果在编程方面接触的比较少,那么对于软件这一块,有几个名词一定要了解,比如开发环
blmius blmius
1年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Easter79 Easter79
1年前
spring事物管理之传播行为和隔离级别
大家在使用spring的注解式事务管理时,对事务的传播行为和隔离级别可能有点不知所措,下边就详细的介绍下以备方便查阅。事物注解方式:@Transactional当标于类前时,表示类中所有方法都进行事物处理例子:@TransactionalpublicclassTestServiceBeanimplementsTest
Wesley13 Wesley13
1年前
@Transactional 回滚不生效原因
事务的管理方式有两种,第一种是编程式事务管理,需要将数据库的自动提交等取消,并且需要自己编写事务代码,第二种则是声明式事务管理模式,spring利用springAOP特性编写了注解即题目中所提到的方式来管理事务,避免开发人员编写大量的事务代码。一、特性先来了解一下@Transactional注解的特性吧,可以更好排查问题1\.service类
Easter79 Easter79
1年前
Spring学习笔记十六
Spring事务ACID原子性一致性隔离性持久性编程式/声明式Spring事务管理抽象是PlatformTransactionManagerJDBC:DataSourceTransactionManagerJTA:JtaTransactionManagerHibernate:Hibern
Wesley13 Wesley13
1年前
Mysql的学习6____事物,索引,备份,视图,触发器
1.Mysql事务:就是将一组的SQL语句放在一个批次去执行,要是一条语句出错,该批次的SQL语句都会取消执行。Mysql事物处理只支持InnoDB和BDB数据表类型。1.1事物的ACID原则:原子性(Atomic):事物中的SQL语句要么全部执行,要么全不执行,不可能停滞在中间的某个状态,若在执行中发生了错误,会进行事物的回滚(Rol
一个关于SDWAN单臂部署方案验证的实验
假设有这样一张网络,其中RTA和PCA表示某公司的A分支,通过中国电信CT路由器接入互联网ISP;RTB和PCB表示某公司的B分支,通过中国联通CU路由器接入互联网ISP。DNS(8.8.8.8)表示某互联网应用。为实现A分支私网192.168.2.0/24和B分支私网192.168.3.0/24的互通,现计划使用某厂商的SDWAN方案进打通两个内网,像下图
SPDK对接Ceph性能优化
关键词:SPDK、NVMeOF、Ceph、CPU负载均衡SPDK是intel公司主导开发的一套存储高性能开发套件,提供了一组工具和库,用于编写高性能、可扩展和用户态存储应用。它通过使用一些关键技术实现了高性能:1.将所有必需的驱动程序移到用户空间,以避免系统调用并且支持零拷贝访问2.IO的完成通过轮询硬件而不是依赖中断,以降低时延3.使用消息传递,以避免IO
helloworld_34035044 helloworld_34035044
8个月前
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
3A网络 3A网络
5个月前
理解 virt、res、shr 之间的关系(linux 系统篇)
理解virt、res、shr之间的关系(linux系统篇)前言想必在linux上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题——你的程序在运行时占用了多少内存(物理内存)?通常我们可以通过t
3A网络 3A网络
5个月前
开发一个不需要重写成 Hive QL 的大数据 SQL 引擎
开发一个不需要重写成HiveQL的大数据SQL引擎学习大数据技术的核心原理,掌握一些高效的思考和思维方式,构建自己的技术知识体系。明白了原理,有时甚至不需要学习,顺着原理就可以推导出各种实现细节。各种知识表象看杂乱无章,若只是学习