mysql事务

问题

概要

  1. storage engine必须支持事务
  2. 事务根据隔离级别的不同,不同事务之间有不同的可见性
  3. begin 或者 start transaction, 显式开启事务;commit显示提交事务;rollback显式回滚事务
  4. autocommit=1时,每条sql语句会自动开启和提交事务;在显示开启事务后,autocommit被自动关闭,事务结束后,autocommit又自动恢复
  5. 也有一些操作会导致事务被隐式提交,比如DML语句,开始新的事务(将自动提交前一个事务)等
  6. 事务执行期间,会根据执行的sql语句,获取一系列锁,这些锁的获取可能会导致死锁,存储引擎也会根据不同的sql语句可能增加额外的锁

事务中可能发生的问题

  1. 脏读

    1. T1第一次查询到a=1, T2修改a=2,T1再查询到a的值就是2,这时候就说T1发生了脏读,因为读到的a的值发生了变化
    2. 一般是T1读到了T2未提交的数据更新
  2. 不可重复读
    1. T1查询到table1有1一条数据a=1,T2 set a=2, T2再次读取时发现a=2
    2. 情形和脏读有点像,但是不可重复读,读到的是其他事务已提交的数据更新
  3. 幻读
    1. T1查询到a=1, T2 insert b=2, T1 再次查询发现有两条记录a=1, b=2,此时对于T1来说,就发生了幻读
    2. 一般是说相同的sql语句,但是得到不同的结果集,可能是多了(insert)或者少了(delete)
    3. 参看https://dev.mysql.com/doc/refman/5.7/en/innodb-next-key-locking.html

隔离级别

  1. RU Read Uncommited , 脏读
  2. RC Read Commited ,不可重复读
  3. RR Repeated Read , 幻读,通过MVVC机制,可以有效缓解幻读的问题
  4. SERIALIZATION, 事务依次顺序提交,不会发生上述的问题,但是性能低下

    参看 https://www.cnblogs.com/zhoujinyi/p/3437475.HTML

MVVC

代码梳理

// sql/sql_parse.cc:mysql_execute_command
// 事务开始
// case SQLCOM_BEGIN:
if (trans_begin(thd, lex->start_transaction_opt)) { // 释放事务锁,其他错误处理,忽略} // sql/transaction.cc
trans_begin:
if (trans_check(thd) DEBUG_RETURN(TRUE);
if (thd->in_multi_stmt_transaction_mode() ||
(thd->variables.option_bits & OPTION_TABLE_LOCK)) {
thd->server_status &= ~SERVER_STATUS_IN_TRANS;
res = test(ha_commit_trans(thd, TRUE));
}
if (res) DEBUG_RETURN(TRUE);
// 待解,啥是consistent_snapshot
if (flags & MYSQL_START_TRANS_OPT_WITH_CONS_SNAPSHOT)
res = ha_start_consistent_snapshot(thd); // 事务提交
// case SQLCOM_COMMIT:
if (trans_commit(thd)) { //释放事务锁,其他错误处理,忽略} // sql/transaction.cc
trans_commit:
trans_check(thd);
res = ha_commit_trans(thd, TRUE);
# 如果res==0, 则事务提交成功
if (res)
RUN_HOOK(transaction, after_rollback, (thd, FALSE));
else
RUN_HOOK(transaction, after_commit, (thd, FALSE)); // sql/handler.cc
ha_commit_trans:
// 如果是读写事务
if (thd->mdl_context.acquire_lock(&mld_request, thd->variables.lock_wait_timeout)) {
ha_rollback_trans(thd, all
}
// 如果是非两阶段事务,则直接提交
if (trans->no_2pc || (rw_ha_count <= 1)) {
error = ha_commit_one_phase(thd, all);
goto done;
} ha_commit_one_phase:
res = commit_one_phase_2(thd, all, trans, is_real_trans); commit_one_phase_2:
// 所有参与本次事务的存储引擎
Ha_trx_info *ha_info = trans->ha_list, *ha_info_next;
if (ha_info) {
for(; ha_info; ha_info = ha_info_next) {
handlerton *ht = ha_info->ht();
if (( err = ht->commit(ht, thd, all))) {
// 存储引擎commit失败,错误处理
}
ha_info_next = ha_info->next();
// 不解,直接reset后,怎么释放ha_info
ha_info->reset();
}
}

mysql事务-简介的更多相关文章

  1. MySQL(十三)之MySQL事务

    前言 这段时间自己会把之前学的东西都总结一遍,希望对自己以后的工作中有帮助.其实现在每天的状态都是很累的,但是我要坚持! 进入我们今天的正题: 为什么MySQL要 有事务呢?事务到底是用来干什么的?我 ...

  2. MySQL日志简介

    一.MySQL日志简介 二.错误日志 作用: 记录mysql数据库的一般状态信息及报错信息,是我们对于数据库常规报错处理的常用日志. 默认位置: $MYSQL_HOME/data/ 开启方式:(MyS ...

  3. MySQL——事务(transaction)简单总结

    简介: MySQL事务操作主要用于处理操作量大,复杂度高的数据,比如说,在人员管理系统中要删除一个人员,你既要删除他的基本资料,也要删除该人员的相关信息,如文章.信箱等.这些数据库操作语句就构成了一个 ...

  4. mysql事务与锁机制详解

    一.事务 1.事务简介 (1)事务的场景 转账:一个账户减少,另一个账户增加.两个动作同时成功或者同时失败.就要开启事务. (2)事务定义 事务是数据库管理系统执行过程中的一个逻辑单元,由一个有限的数 ...

  5. 超干货!为了让你彻底弄懂MySQL事务日志,我通宵肝出了这份图解!

    还记得刚上研究生的时候,导师常挂在嘴边的一句话,"科研的基础不过就是数据而已."如今看来,无论是人文社科,还是自然科学,或许都可在一定程度上看作是数据的科学. 倘若剥开研究领域的外 ...

  6. 熬夜肝出5大点,18张图带你彻底弄懂MySQL事务日志

    在当今社会,充斥着大量的数据.从众多APP上的账户资料到银行信用体系等个人档案,都离不开对大量数据的组织.存储和管理.而这,便是数据库存在的目的和价值.目前数据库的类型主要分为两种,一种是关系型数据库 ...

  7. mysql事务、隔离级别

    一.事务简介 事务是一组操作的集合,它是一一个不可分割的工作单位,事务会把所有的操作作为- -个整体一起向系统提交或撤销操作请求,即这些操作要么同时成功,要么同时失败. 二.有关事务操作 mysql中 ...

  8. Java开发学习(二十一)----Spring事务简介与事务角色解析

    一.Spring事务简介 1.1 相关概念介绍 事务作用:在数据层保障一系列的数据库操作同成功同失败 Spring事务作用:在数据层或业务层保障一系列的数据库操作同成功同失败 数据层有事务我们可以理解 ...

  9. MySQL事务概念与流程和索引控制

    MySQL事务概念与流程和索引控制 视图 1.什么是视图 我们在执行SQL语句其实就是对表进行操作,所得到的其实也是一张表,而我们需要经常对这些表进行操作,拼接什么的都会产生一张虚拟表,我们可以基于该 ...

随机推荐

  1. PyQt(Python+Qt)学习随笔:QDockWidget停靠部件的allowedAreas属性

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 QDockWidget的allowedAreas属性用于控制停靠部件在 ...

  2. 如何利用Excel快速批量生成想要的代码

    如何利用Excel快速批量生成想要的代码 使用场景 在HTML DOM Video 对象这个页面 我想要将所有的中文描述和对应的属性(共32个属性)打印出来--console.log(descript ...

  3. 搭建伪分布式 hadoop3.1.3 + zookeeper 3.5.7 + hbase 2.2.2

    安装包 Hadoop 3.1.3 Zookeeper 3.5.7 Hbase 2.2.2 所需工具链接: 链接:https://pan.baidu.com/s/1jcenv7SeGX1gjPT9RnB ...

  4. 建立SQL Server用户登录

    第一步:右击服务器名,点击"属性",选择"安全性",选中"Sql server和Windows身份验证模式". 第二步:鼠标右键点击安全性中 ...

  5. SQLMap使用指北

    简介 sqlmap是一个开源的渗透测试工具,可以用来进行自动化检测,利用SQL注入漏洞,获取数据库服务器的权限.它具有功能强大的检测引擎,针对各种不同类型数据库的渗透测试的功能选项,包括获取数据库中存 ...

  6. TMOOC 1969 开锁

    update on 2020.2.28 时隔近日重新想这道题,其实复杂度正确的解法是 可持久化 01 Trie. 考虑对于每一个 \(a[i]\),考虑能将它作为最大值的最大包容区间 \([l, r] ...

  7. Luogu-P3205-HNOI2010-合唱队

    题目地址 思路 这道题其实是P3146 [USACO16OPEN]248的升级版,但是N的范围很大,为262144.原先的O(N3)的方法自然会TLE,甚至O(N2)的方法也不足以解决. 定义f[i] ...

  8. Fisco Bcos学习资料连接

    大牛博客:http://m.blog.csdn.net/sportshark FISCO BCOS学习资料索引;http://kb.bsnbase.com/webdoc/view/Pub4028813 ...

  9. Spark SQL 小文件问题处理

    在生产中,无论是通过SQL语句或者Scala/Java等代码的方式使用Spark SQL处理数据,在Spark SQL写数据时,往往会遇到生成的小文件过多的问题,而管理这些大量的小文件,是一件非常头疼 ...

  10. 2020-2021-1 20209307 《Linux内核原理与分析》第八周作业

    这个作业属于哪个课程 <2020-2021-1Linux内核原理与分析)> 这个作业要求在哪里 <2020-2021-1Linux内核原理与分析第八周作业> 这个作业的目标 & ...