事务 与 事务隔离

        事务就是要保证一组数据库操作,要么全部成功,要么全部失败。再MySQL中,事务支持是在引擎层实现的。MySQL是一个支持多引擎的系统,但并不是所有的引擎都支持事务。在 MySQL 中只有使用了 Innodb 数据库引擎的数据库或表才支持事务。比如MySQL原生的MyISAM引擎就不支持事务,这也就是MyISAM被InnoDB取代的重要原因之一。事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。事务用来管理 insert,update,delete 语句。

    一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。

事务控制语句:

BEGIN 或 START TRANSACTION 显式地开启一个事务;

COMMIT 也可以使用 COMMIT WORK,不过二者是等价的。COMMIT 会提交事务,并使已对数据库进行的所有修改成为永久性的;

ROLLBACK 也可以使用 ROLLBACK WORK,不过二者是等价的。回滚会结束用户的事务,并撤销正在进行的所有未提交的修改;

SAVEPOINT identifier,SAVEPOINT 允许在事务中创建一个保存点,一个事务中可以有多个 SAVEPOINT;

RELEASE SAVEPOINT identifier 删除一个事务的保存点,当没有指定的保存点时,执行该语句会抛出一个异常;

ROLLBACK TO identifier 把事务回滚到标记点;

SET TRANSACTION 用来设置事务的隔离级别。InnoDB 存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ 和 SERIALIZABLE。

隔离性与隔离级别

        提到事务,必须提到隔离。当数据库上有多个事务同事执行的时候,就可能出现脏读、不可重复读、幻读的问题,为了解决这些问题就有了“隔离级别”的概念。因为隔离越严实,效率越低。我们需要在二者之间寻找一个平衡点。SQL标准的事务隔离级别包括:读未提交、读提交、可重复读和串行化。

事务隔离的实现

        以“可重复读”级别为例,在MySQL中,实际上每条记录在更新的时候都会同事记录一条回滚操作。记录上的最新值,通过回滚操作,都可以得到前一个状态的值。


从图中例子可以看出,即使现在有另外一个事务正在讲4改成5,这个事务跟read-微微A、B、C对应的事务是不会冲突的。但产生回滚日志只有在不需要的时候才删除,也就是说,系统会判断当没有事务再需要用到这些回滚日志的时,回滚日志会被删除的。

所以,不建议使用长事务,因为会导致大量占用存储空间。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 提到事务,你肯定并不陌生,和数据库打交道的时候,我们总是会用到事务。最经典的例子就是转账,你要给朋友小王转100元...
    allen成阅读 555评论 0 0
  • 提到事务,你肯定不陌生,和数据库打交道的时候,我们总是会用到事务。最经典的例子就是转账,你要给朋友小王转100块钱...
    旦暮何枯阅读 675评论 0 0
  • 提到事务,你肯定不陌生,和数据库打交道的时候,我们总是会用到事务。最经典的例子就是转账,你要给朋友小王转 100 ...
    pixelczx阅读 691评论 2 1
  • 事务就是要保证一组数据库操作,要么全部成功,要么全部失败。在MySQL中,事务支持是在引擎层实现的。MySQL是一...
    花神子阅读 380评论 0 2
  • 尊敬的领导,亲爱的兄弟姐妹们,大家好!在最近这七天的工作中,最主要的工作就是去展厅进行对各类产品的实际话术演练。 ...
    任纪伟阅读 2,646评论 1 0