mysql 事务 spring事务处理

数据库事务

数据库事务(Database Transaction) ,是指作为单个逻辑工作单元执行的一系列操作,
要么完全地执行,要么完全地不执行。
一个逻辑工作单元要成为事务,必须满足所谓的ACID(原子性、一致性、隔离性和持久性)属性。
原子性 (Atomic)
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。(整体)
一致性(Consistent)
事务在完成时,必须使所有的数据都保持一致状态。(完成)
隔离性(Insulation)
由并发事务所做的修改必须与任何其它并发事务所做的修改隔离。(并发)
持久性(Duration)
事务完成以后,它对于系统的影响是永久性的。该修改即使出现致命的系统故障已将一直保持。(结果)

隔离问题

脏读
一个事务读到另一个事务没有提交的数据。
不可重复读
一个事务读取到另一个事务已提交的数据(update)。
虚度(幻读)
一个事务读取到另一个事务已提交的数据(insert)。

隔离级别

  • read uncommitted: 读未提交。存在以上3个问题。
  • read committed:读已提交。解决脏读,存在2个问题。
  • repeatable read: 可重复读。解决:脏读,不可重复读,存在1个问题。
  • serializable: 串行化。都解决,单事务。
mysql事物操作
Connection conn = null;
try{
    //1 数据库链接
    conn = ...
    //2 开启事物
    conn.setAutoCommit(false);
    操作A
    操作B
    操作C
    操作D
    
    //3 提交事务
    conn.commit();
    
} catche() {
    //4 回滚事务
    conn.rollback();
}
mysql事务操作保存点(Savepoint)
Connection conn = null;
//保存点,记录操作的当前位置,之后可以回滚到指定的位置.(可以回滚一部分)
Savepoint savepoint = null;
try{
    //1 数据库链接
    conn = ...
    //2 开启事物
    conn.setAutoCommit(false);
    操作A
    操作B
    savepoint = conn.setSavepoint();
    操作C
    操作D
    //3 提交事务
    conn.commit();
} catche() {
    //4 回滚事务
    if(savepoint != null) { // CD异常
        //回滚到CD之前
        conn.rollback(savepoint)
        //提交AB
        conn.commit();
    } else {
        //回滚AB
        conn.rollback();
    }
}

spring 事物管理介绍

添加jar包 spring-tx-4.3.5.RELEASE.jar。

  • PlatformTranscationManager 平台事物管理器,spring 要管理事务,必须使用事物管理器。
    进行事务配置时,必须配置事物管理器。
  • TransactionDefinition:事物详情(事务定义,事务属性),spring用于确定事物具体详情,例如
    隔离级别,是否读取,超时等。
    进行事物配置时,必须配置详情。spring 将配置项封装到该对象实例。
  • TransactionStatus: 事务状态,spring用于记录当前事务运行状态。
    是否有保存点,事务是否完成。

PlatformTransactionManager 事务管理器

导入jar包:需要平台事物管理器的实现类。
  • spring-jdbc-4.3.5.RELEASE.jar jdbc开发
  • spring-orm-4.3.5.RELEASE 整合hibernate
常见的事物管理器

DataSourceTransactionManager jdbc开发时事物管理器,采用JdbcTemplate。
HibernateTransactionManager hibernate开发时事物管理器,整合hibernate。

  • api方法
    TransactionStatus getTransaction(TransactionDefinition var1) 事务管理器 通过“事务详情”,获得“事物状态”,从而管理事务。

void commit(TransactionStatus status) 根据状态提交
void rollback(TransactionStatus status) 根据状态回滚

TransactionStatus 事务状态

  • boolean isNewTransaction(); 是否是新事物
  • boolean hasSavepoint(); 是否有保存点
  • void setRollbackOnly(); 设置回滚
  • boolean isRollbackOnly(); 是否回滚
  • void flush(); 刷新
  • boolean isCompleted(); 是否完成

TransactionDefinition 事物详情(事务定义,事务属性)

//传播行为
int PROPAGATION_REQUIRED = 0;
int PROPAGATION_SUPPORTS = 1;
int PROPAGATION_MANDATORY = 2;
int PROPAGATION_REQUIRES_NEW = 3;
int PROPAGATION_NOT_SUPPORTED = 4;
int PROPAGATION_NEVER = 5;
int PROPAGATION_NESTED = 6;

//隔离级别
int ISOLATION_DEFAULT = -1;
int ISOLATION_READ_UNCOMMITTED = 1;
int ISOLATION_READ_COMMITTED = 2;
int ISOLATION_REPEATABLE_READ = 4;
int ISOLATION_SERIALIZABLE = 8;

//默认超时时间。默认值 -1.使用数据库底层的超时时间
int TIMEOUT_DEFAULT = -1;

int getPropagationBehavior();  传播行为
int getIsolationLevel();       隔离级别
int getTimeout();           获得超时时间
boolean isReadOnly();   是否只读(增删改:读写; 查询:只读)
String getName();       配置事务详情名称。一般方法名称。例如:save,add* 等。
  • 传播行为:在两个业务之间如何共享事务。

    • PROPAGATION_REQUIRED , required , 必须 【默认值】
      支持当前事务,A如果有事务,B将使用该事务。
      如果A没有事务,B将创建一个新的事务。
    • PROPAGATION_SUPPORTS ,supports ,支持
      支持当前事务,A如果有事务,B将使用该事务。
      如果A没有事务,B将以非事务执行。
    • PROPAGATION_MANDATORY,mandatory ,强制
      支持当前事务,A如果有事务,B将使用该事务。
      如果A没有事务,B将抛异常。
    • PROPAGATION_REQUIRES_NEW , requires_new ,必须新的
      如果A有事务,将A的事务挂起,B创建一个新的事务
      如果A没有事务,B创建一个新的事务
    • PROPAGATION_NOT_SUPPORTED ,not_supported ,不支持
      如果A有事务,将A的事务挂起,B将以非事务执行
      如果A没有事务,B将以非事务执行
    • PROPAGATION_NEVER ,never,从不
      如果A有事务,B将抛异常
      如果A没有事务,B将以非事务执行
    • PROPAGATION_NESTED ,nested ,嵌套
      A和B底层采用保存点机制,形成嵌套事务。
  • 经常使用
    PROPAGATION_REQUIRED PROPAGATION_REQUIRES_NEW PROPAGATION_NESTED

事务处理 AOP配置基于xml

  • 使用配置 在spring xml 配置aop自动生成代理,进行事物的管理
    • 1,配置管理器。
    • 2,配置事物详情。
    • 3,配置aop.
xml 配置 applicationContext-tx.xml

<?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:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx.xsd"

<!--组件扫描-->
<context:component-scan base-package="com.springdemo"></context:component-scan>

<bean id="dataSourceId" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl"

              value="jdbc:mysql://localhost:3306/school?useUnicode=true&characterEncoding=UTF-8"></property>
    <property name="user" value="root"></property>
    <property name="password" value=""></property>

</bean>
<bean id="template" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSourceId"></property>
</bean>

<bean id="accountDaoId" class="com.springdemo.dao.impl.AccountDaoImpl">
    <property name="jdbcTemplate" ref="template"></property>
</bean>
<bean id="serviceId" class="com.springdemo.service.impl.AccountServiceImpl">
    <property name="accountDao" ref="accountDaoId"></property>
</bean>

<!--事务管理-->
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSourceId"></property>
</bean>

<!--
事务详情
        <tx:attributes> 用于配置事务详情(属性属性)
        <tx:method name=""/> 详情具体配置
            propagation 传播行为 , REQUIRED:必须;REQUIRES_NEW:必须是新的
            isolation 隔离级别
-->
<tx:advice id="txAdvice" transaction-manager="txManager">
    <tx:attributes>
        <!--事务名称-->
        <tx:method name="transfer" propagation="REQUIRED" isolation="DEFAULT"/>
    </tx:attributes>
</tx:advice>
<!--AOP编程,目标类有ABCD(4个连接点),切入点表达式-->
<aop:config>
    <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.springdemo.service.impl.AccountServiceImpl.*(..))"></aop:advisor>
</aop:config>

</beans>
最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352

推荐阅读更多精彩内容

  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,796评论 6 342
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • 很多人喜欢这篇文章,特此同步过来 由浅入深谈论spring事务 前言 这篇其实也要归纳到《常识》系列中,但这重点又...
    码农戏码阅读 4,724评论 2 59
  • 前言 最近感触颇深,原谅我在开头写心情日记。介意的跳过看正文。 市场 趋势 近几年,技术市场对新人越来越不友好,社...
    IT天宇阅读 12,258评论 5 68
  • 一大早看到这条信息,实在是感觉有些痛心。虽然我不认识胡迁,也不知道他的故事。但经了解一番,知道他是一个作家,已有二...
    正好有空画画阅读 150评论 0 0