了解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; # 正常结束
    
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值