您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

了解mysql-事务介绍

bubuko 2022/1/25 20:03:41 mysql 字数 2049 阅读 703 来源 http://www.bubuko.com/infolist-5-1.html

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

事务

是什么

事务由单独单元的一个或多个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; # 正常结束
    

了解mysql-事务介绍

原文:https://www.cnblogs.com/yhycoder/p/12545193.html


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶