• 了解mysql-事务介绍


    事务

    是什么

    事务由单独单元的一个或多个SQL语句组成,在这个单元中,每一个mysql语句是相互依赖的;由于整个单独单元作为不可分割的整体,那么如果单元中某条SQL语句一旦执行失败或产生失败,整个单元就会回滚。要么全部成功,要么全部失败。

    在mysql中用的最多的存储引擎有:innodb,myisam,memory 等。其中innodb支持事务,而myisam、memory等不支持事务

    查看mysql支持的引擎:SHOW engines
    

    事务的四大特性

    1. 原子性:要么成功,要么失败。
    2. 一致性:状态与其他业务规则保持一致。
    3. 隔离性:在并发中使用。一个事务不被另一个事务所影响
    4. 持久性:一旦改变提交之后,数据就持久化被操作了。

    分类

    隐式事务:没有明显的开启和结束标记
    显式事务:有明显的开启和结束标记
    
    

    使用步骤:

    插个小知识

    DDL(Data Definition Language):数据定义语言,用来定义数据库对象:库、表、列等;
    DML(Data Manipulation Language):数据操作语言,用来定义数据库记录(数据);
    DCL(Data Control Language):数据控制语言,用来定义访问权限和安全级别;
    DQL(Data Query Language):数据查询语言,用来查询记录(数据)。
    
    
    • 一般情况下,如果在一个事务中包含多个SQL语句,那么就要开启事务和结束事务;
    开启事务:start transaction;
    结束事务:commit或rollback。
    
    
    • 开始是以第一个DML语句执行开始

    • 以下面的其中之一作为结束:
      COMMIT 或ROLLBACK 语句(回滚,即回滚到事务的起点,之前做的所有操作都被撤消了!)
      DDL 或DCL 语句(自动提交)
      用户会话正常结束
      系统异常终了

    • START TRANSACTION; # 开启
      UPDATE account SET balance=balance-10000 WHERE id=1;
      UPDATE account SET balance=balance+10000 WHERE id=2;
      COMMIT; # 正常结束
      
      
  • 相关阅读:
    新概念英语(1-121)The man in a hat
    新概念英语(1-119)who call out to the thieves in the dark?
    画像分析(1-1)如何为客户画像?
    大数据分析师
    英语词汇(2)fall down,fall off和fall over
    把梳子卖给和尚的故事
    洛谷P1970 花匠(dp)
    2018.10.24模拟赛2解题报告
    2018.10.24模拟赛1解题报告
    洛谷P1941 飞扬的小鸟(背包 dp)
  • 原文地址:https://www.cnblogs.com/yhycoder/p/12545193.html
Copyright © 2020-2023  润新知