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


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

在当前事务中确实能看到插入的记录。最后只不过删除了。但是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进程来进行回收。



相关阅读:
win7更改U盘背景技巧(附代码)
浅析mysql 语句的调度优先级及改变
jQuery实现图片轮播特效代码分享
C#图像处理之图像平移的方法
win7如何获取管理员权限?win7管理员权限获取方法介绍
关于CSS选择器优先级的判断题附结果截图
使用Promise解决多层异步调用的简单学习心得
win10右键空白处反应慢的解决办法
Mac怎么管理字体如何添加或删除
Win10.1怎么升级更新 Win10.1在线升级与ISO镜像升级方法介绍
Ubuntu14.04唤醒睡眠后鼠标键盘出现卡死情况
分享CSS3制作卡片式图片的方法
Java中的Calendar日历API用法完全解析
Linux系统上Samba服务器的配置教程
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 酷热中安好作文600字 体验生活作文600字 日出作文1000字 一个人也可以很快乐 路·桥700字 促进教师专业成长实施方案 豆贴画 留恋我大一的那所分校 什么最解渴 践行科学发展观实事求是自我剖析 未来如何交给时间 《过去和回忆》 村里的供销社 室内设计师年终工作总结 梦哆嗦 《皮皮鲁和病菌老大》读后感作文600字 《技术世界中的设计》知识点归纳 幼儿园大班美术欣赏:张大千《荷花》 我运动我快乐350字 单位申请入党 秋景让我陶醉 高中高三作文5200字:大自然的启示的资料(高中) 你的淡香,让我记住了你 一个肾脏的男人 班里有个热心人600字 我爱家乡的小河左佳辉作文350字 魔鬼教官,魔鬼训练场 2013年一个置业顾问的年终总结 我的艺术生活作文800字 2013年党建工作计划目标 希望为话题的作文 道德模范视频观后感 班主任工作经验交流材料(21) 情感日志 生命中不可或缺的你 读钉子的故事有感 一条最孤独的鲸 春天的好词好句 描写春天的好词好句 夜凉如水~风舞画屏 想要与众不同就接受自己的瑕疵 自信作文 那年的第一场雪 回想半年的高中生活 我最自豪的一件事作文1200字 亲爱的,这一秒你为自己而活 欢度春节作文 小学六年级作文900字:无辜 奶奶一步步走远 校园操场 连锁超市财务管理 食品安全形势分析报告

Copyright © 2016 phpStudy |