------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥-------------

本篇博客会详细讲述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中的事务是什么?》的更多相关文章

  1. spring + myBatis 常见错误:注解事务不回滚

    最近项目在用springMVC+spring+myBatis框架,在配置事务的时候发现一个事务不能回滚的问题. 刚开始配置如下:springMVC.xml配置内容: spring.xml配置内容 从上 ...

  2. SQL Server 中的事务与事务隔离级别以及如何理解脏读, 未提交读,不可重复读和幻读产生的过程和原因

    原本打算写有关 SSIS Package 中的事务控制过程的,但是发现很多基本的概念还是需要有 SQL Server 事务和事务的隔离级别做基础铺垫.所以花了点时间,把 SQL Server 数据库中 ...

  3. SQL Server中的事务与其隔离级别之脏读, 未提交读,不可重复读和幻读

    原本打算写有关 SSIS Package 中的事务控制过程的,但是发现很多基本的概念还是需要有 SQL Server 事务和事务的隔离级别做基础铺垫.所以花了点时间,把 SQL Server 数据库中 ...

  4. Spring中@Transactional事务回滚实例及源码

    一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除 ...

  5. Spring中@Transactional事务回滚(含实例详细讲解,附源码)

    一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部门里面有很多成员,这两者分别保存在部门表和成员表里面,在删除 ...

  6. Spring,SpringMvc配置常见的坑,注解的使用注意事项,applicationContext.xml和spring.mvc.xml配置注意事项,spring中的事务失效,事务不回滚原因

    1.Spring中的applicationContext.xml配置错误导致的异常 异常信息: org.apache.ibatis.binding.BindingException: Invalid ...

  7. Spring中@Transactional事务回滚

    转载: Spring中@Transactional事务回滚 一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用.下面举个栗子:比如一个部 ...

  8. 程序员笔记|Spring IoC、面向切面编程、事务管理等Spring基本概念详解

    一.Spring IoC 1.1 重要概念 1)控制反转(Inversion of control) 控制反转是一种通过描述(在java中通过xml或者注解)并通过第三方去产生或获取特定对象的方式. ...

  9. Spring中@Transactional事务回滚(含实例具体解说,附源代码)

    一.使用场景举例 在了解@Transactional怎么用之前我们必须要先知道@Transactional有什么用. 以下举个栗子:比方一个部门里面有非常多成员,这两者分别保存在部门表和成员表里面,在 ...

随机推荐

  1. BZOJ1996:[HNOI2010]CHORUS 合唱队(区间DP)

    Description Input Output Sample Input 4 1701 1702 1703 1704 Sample Output 8 HINT Solution 辣鸡guide真难用 ...

  2. 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 ...

  3. ServletRequest的四个主要方法

    package com.yunqing.servlet; import javax.servlet.*; import java.io.IOException; import java.util.Ar ...

  4. torch.backend.cudnn.benchmark

    大部分情况下,设置这个 flag 可以让内置的 cuDNN 的 auto-tuner 自动寻找最适合当前配置的高效算法,来达到优化运行效率的问题. 一般来讲,应该遵循以下准则: 如果网络的输入数据维度 ...

  5. PAT——1045. 快速排序

    著名的快速排序算法里有一个经典的划分过程:我们通常采用某种方法取一个元素作为主元,通过交换,把比主元小的元素放到它的左边,比主元大的元素放到它的右边. 给定划分后的N个互不相同的正整数的排列,请问有多 ...

  6. 数据库——MySQL——索引

    索引的功能就是加速查找,MySQL中的primary key,unique,联合唯一也都是索引,只是这些索引除了加速查找以外,还有约束功能. 一般的应用系统,读写比例在10:1左右,而且插入操作和一般 ...

  7. 如何搭建私人的ghost博客

    可参考 http://blog.pandax.me/cjbk/ 此文

  8. ASP.Net Mvc 5 学习记录2015-9-9

    我之前一直都是学习和开发都采用ASP.Net WebForm,对MVC的一直都是一知半解,最初以为ASP.Net WebForm的N层架构就是MVC.其实N层架构设计思想是"高内聚,低耦合& ...

  9. oracle带输入输出参数存储过程(包括sql分页功能)

    记录一下,免得以后忘记了又要到处去找. begin /*这里不能直接执行select语句但可以直接执行update.delete.insert语句*/ end里面不能接执行select语句,声明会话级 ...

  10. Oracle死锁一例(ORA-00060),锁表导致的业务死锁问题

    1.问题发现 检查客户数据库的时候发现存在大量死锁的情况 Thread advanced to log sequence (LGWR switch) Current log# mem# : /orad ...