• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MYSQL事务回滚的2个问题分析

MYSQL事务回滚的2个问题分析

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mysql事务回滚,mysql数据库事务回滚,mysql事务,mysql事务隔离级别,mysql事务提交等相关知识,希望本文的分享对您有所帮助

因此,正确的原子操作是真正被执行过的。是物理执行。

在当前事务中确实能看到插入的记录。最后只不过删除了。但是AUTO_INCREMENT不会应删除而改变值。

1、为什么auto_increament没有回滚?

因为innodb的auto_increament的计数器记录的当前值是保存在存内存中的,并不是存在于磁盘上,当mysql server处于运行的时候,这个计数值只会随着insert改增长,不会随着delete而减少。而当mysql server启动时,当我们需要去查询auto_increment计数值时,mysql便会自动执行:SELECT MAX(id) FROM 表名 FOR UPDATE;语句来获得当前auto_increment列的最大值,然后将这个值放到auto_increment计数器中。所以就算 Rollback MySQL的auto_increament计数器也不会作负运算。

2、MySQL的事务对表操作的时候是否是物理操作?

MySQL的事务是有redo和undo的,redo操作的所有信息都是记录到 redo_log中,也就是说当一个事务做commit操作时,需要先把这个事务的操作写到redo_log中,然后再把这些操作flush到磁盘上,当 出现故障时,只需要读取redo_log,然后再重新flush到磁盘就行了。

而对于undo就比较麻烦,MySQL在处理事务时,会在数据共享 表空间里申请一个段叫做segment段,用保存undo信息,当在处理rollback,不是完完全全的物理undo,而是逻辑undo,就是说会对之 前的操作进行反操作,但是这些共享表空间是不进行回收的。这些表空间的回收需要由mysql的master thread进程来进行回收。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • MySql事务无法回滚的原因有哪些
  • MYSQL事务回滚的2个问题分析
  • Mysql中的事务是什么如何使用

相关文章

  • 2018-12-05对MySQL的初步了解
  • 2017-05-11MYSQL 数据库命名与设计规范
  • 2018-12-05mysql中实现七表查询实例(二)
  • 2018-12-05Mysql中limit的用法详解
  • 2018-12-05Oracle数据库密码文件的使用与维护
  • 2018-12-05MySQL数据库优化(一)—MySQL引擎
  • 2017-05-11MySQL中的if和case语句使用总结
  • 2017-05-11如何选择合适的MySQL存储引擎
  • 2018-12-05MySQL索引设计一些策略_MySQL
  • 2018-12-05mysql 协议的认证包及代码详情介绍

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Mysql 开启Federated引擎的方法
    • mysql_insert_id()函数的文章推荐10篇
    • MS Server和Oracle中对NULL处理的一些细节差异
    • mysql 设置默认的时间值
    • 怎样设置才能允许外网访问MySQL
    • 使用MySQL数据库(4)创建数据库表
    • Debian 6.02 (squeeze)下编译安装 MySQL 5.5的方法
    • MySQL子查询的详细介绍
    • MySQL中prepare与execute以及deallocate预处理语句的使用教程
    • Sysbench多线程性能测试工具

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有