SSM-Spring-23:概念《Spring中的事务是什么?》
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------
本篇博客会详细讲述Spring中的事务,会展开来用语言解释,用于了解概念和准备面试
事务的概念:
一个或者一组sql语句来完成一个功能!要么都执行,要么都不执行
事务具有的四个特性: ACID特性!
01.原子性:一个事物都是一个不可分割的单位!所有的操作 要么都执行,要么都不执行!
02.一致性:事务必须是数据库从一个一致性的状态到达另一个一致性的状态!
03.隔离性:一个事务的执行不会被其他的事务干扰!事务之间相互独立!
04.持久性:事务一旦被提交!这个操作对数据库来说是永久性的!
Spring的事务管理:
事务本事是数据库中的概念! 按理说应该在数据访问层(dao)!
绝大多数的情况下,我们是把事务 提升到 业务逻辑层!
01.使用spring的事务代理工厂 来 管理事务!
02.使用spring的注解 来 管理事务! 常用
03.使用AspectJ的AOP配置 来 管理事务! 常用
需要掌握的两个属性名:
isolation:事务的隔离级别!
01.default:采用数据库默认的事务隔离级别
001.mysql ---》repeatable-read
002.oracle---》read_committed
02. repeatable-read:可重复读取!解决了脏读,不可重复读,没解决幻读!
03. read_committed:读已提交! 解决了脏读,没解决不可重复读,幻读!
04. read_uncommitted:读未提交!什么都没有解决!
05. serializable:串行化!级别最高!效率最低!不存在并发的问题!
propagation: 事务的传播行为:一共7中方式!
01.required:是spring默认的事务传播行为!
指定的方法必须在事务中执行!如果没有事务,则会自动创建一个事务!
02.supports:有事务就在事务环境下执行,没有事务就直接执行!
03.mandatory:
指定的方法必须在事务中执行!如果没有事务,则抛出异常!
04.requires_new:总是新创建一个事务!
如果当前方法存在事务,则把当前的事务挂起,直到新创建的事务执行完毕后执行!
05.not_supported:指定的方法不能在事务中执行!如果当前方法存在事务,则把当前的事务挂起!
06.never:指定的方法不能在事务中执行!如果当前方法存在事务,则抛出异常!
07.nested:指定的方法必须在事务内执行!
如果执行的方法没有事务,则会创建一个事务!
如果执行的方法没有事务,则会嵌套执行!
timeout_default:定义了事务默认的超时时间!
Spring事务管理的接口:PlatformTransactionManager
常用的两个实现类:
01.使用jdbc和MyBatis时 使用DataSourceTrancationManager
02.使用hibernate时 使用HibernateTrancationManager
Spring事务回滚的方式:
默认的回滚方式--》发生运行时异常回滚!发送受查异常时提交!
受查异常肯定需要我们手动的设置回滚方式!
运行时异常严重!一旦发生,JVM中止执行!
实现自定义异常类!RuntimeException --> Exception ---> Throwable
SSM-Spring-23:概念《Spring中的事务是什么?》的更多相关文章
- spring + myBatis 常见错误:注解事务不回滚
最近项目在用springMVC+spring+myBatis框架,在配置事务的时候发现一个事务不能回滚的问题. 刚开始配置如下:springMVC.xml配置内容: spring.xml配置内容 从上 ...
- SQL Server 中的事务与事务隔离级别以及如何理解脏读, 未提交读,不可重复读和幻读产生的过程和原因
原本打算写有关 SSIS Package 中的事务控制过程的,但是发现很多基本的概念还是需要有 SQL Server 事务和事务的隔离级别做基础铺垫.所以花了点时间,把 SQL Server 数据库中 ...
- SQL Server中的事务与其隔离级别之脏读, 未提交读,不可重复读和幻读
原本打算写有关 SSIS Package 中的事务控制过程的,但是发现很多基本的概念还是需要有 SQL Server 事务和事务的隔离级别做基础铺垫.所以花了点时间,把 SQL Server 数据库中 ...
- Spring中@Transactional事务回滚实例及源码
一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除 ...
- Spring中@Transactional事务回滚(含实例详细讲解,附源码)
一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除 ...
- Spring,SpringMvc配置常见的坑,注解的使用注意事项,applicationContext.xml和spring.mvc.xml配置注意事项,spring中的事务失效,事务不回滚原因
1.Spring中的applicationContext.xml配置错误导致的异常 异常信息: org.apache.ibatis.binding.BindingException: Invalid ...
- Spring中@Transactional事务回滚
转载: Spring中@Transactional事务回滚 一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部 ...
- 程序员笔记|Spring IoC、面向切面编程、事务管理等Spring基本概念详解
一.Spring IoC 1.1 重要概念 1)控制反转(Inversion of control) 控制反转是一种通过描述(在java中通过xml或者注解)并通过第三方去产生或获取特定对象的方式. ...
- Spring中@Transactional事务回滚(含实例具体解说,附源代码)
一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用. 以下举个栗子:比方一个部门里面有非常多成员,这两者分别保存在部门表和成员表里面,在 ...
随机推荐
- BZOJ1996:[HNOI2010]CHORUS 合唱队(区间DP)
Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Solution 辣鸡guide真难用 ...
- scp出现ssh port 22: Connection refused 问题解决具体步骤
[root(0)@sys11 09:20:29 /home/work/Code_release/bj]# scp ./release.sh root@192.168.161.151:/Users/a ...
- ServletRequest的四个主要方法
package com.yunqing.servlet; import javax.servlet.*; import java.io.IOException; import java.util.Ar ...
- torch.backend.cudnn.benchmark
大部分情况下,设置这个 flag 可以让内置的 cuDNN 的 auto-tuner 自动寻找最适合当前配置的高效算法,来达到优化运行效率的问题. 一般来讲,应该遵循以下准则: 如果网络的输入数据维度 ...
- PAT——1045. 快速排序
著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边. 给定划分后的N个互不相同的正整数的排列,请问有多 ...
- 数据库——MySQL——索引
索引的功能就是加速查找,MySQL中的primary key,unique,联合唯一也都是索引,只是这些索引除了加速查找以外,还有约束功能. 一般的应用系统,读写比例在10:1左右,而且插入操作和一般 ...
- 如何搭建私人的ghost博客
可参考 http://blog.pandax.me/cjbk/ 此文
- ASP.Net Mvc 5 学习记录2015-9-9
我之前一直都是学习和开发都采用ASP.Net WebForm,对MVC的一直都是一知半解,最初以为ASP.Net WebForm的N层架构就是MVC.其实N层架构设计思想是"高内聚,低耦合& ...
- oracle带输入输出参数存储过程(包括sql分页功能)
记录一下,免得以后忘记了又要到处去找. begin /*这里不能直接执行select语句但可以直接执行update.delete.insert语句*/ end里面不能接执行select语句,声明会话级 ...
- Oracle死锁一例(ORA-00060),锁表导致的业务死锁问题
1.问题发现 检查客户数据库的时候发现存在大量死锁的情况 Thread advanced to log sequence (LGWR switch) Current log# mem# : /orad ...