• 【MySQL】MySQL事务隔离机制与实现原理详解


    本文导读

    本文介绍MySQL事务的使用和其存在长事务的风险, MySQL 的事务及其特性,并发事务带来的问题、事务的隔离级别与演示,单版本控制锁以及多版本并发控制 MVCC。

    一、MySQL事务使用

    1、什么是事务

    事务是作为单个逻辑工作单元执行的一系列操作。这些操作要么全部,要么没有,是一个不可分割的工作单元。

    例如,购买东西支付的过程中会有一系列操作,如查询余额、加减、更新余额。这些操作必须是同时的。否则,显示你支付成功,但是系统没有收到钱

    在MySQL中,事务支持是在引擎层实现的,MyISAM引擎不支持事务

    2、事务的四个特性

    要成为事务,逻辑工作单元必须满足关系数据库管理系统中的四个特征。

    即所谓的ACID:原子性、一致性、隔离性、持久性。

    原子性:事务的所有操作要么完成要么未完成,不会在中间阶段结束。

    一致性:在事务之前和之后,数据库的完整性限制不会被打破。

    隔离性:当多个事务同时访问数据库中的同一数据时,将显示关系。

    持久性:事务完成后,事务所做的更改将持久保存,不会丢失。

    ACID 需要通过 Redo 和 Undo 日志来保证。MySQL日志系统详解:(后续补充)

    3、MySQL事务使用

    MySQL 的事务启动方式有以下2种:

    3.1、显式启动事务语句

    begin 或 start transaction。配套的提交语句是 commit,回滚语句是 rollback。

    BEGIN -- 开启事务
    START TRANSACTION -- 开启事务
    
    INSERT INTO fork_business_detail VALUES ( 4, '123'
    • 1
    • 2
    • 3
  • 相关阅读:
    网络编程中的并发控制
    hadoop使用笔记
    Ceph qos 限速
    基于EasyCVR视频监控技术在物流仓储行业的应用
    黑*头条_第7章_kafka实战应用&文章自动审核
    (一). 贝叶斯滤波器
    Linux启动过程基本指南
    java基于SpringBoot+vue 的简历模板分享系统 elementui前后端分离
    kubeadm安装kubernetes集群
    深入理解mysql事务本质(超级详解)
  • 原文地址:https://blog.csdn.net/Huangjiazhen711/article/details/127843715