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 交通频道 作文范文 森林演唱会作文200字 给自己一份自信 中学中层领导学习培训感想 春季干部集训个人剖析材料 读懂你,我用了十年 夏小叶和树的对话 风中的叶 妻子决定丈夫寿命?哪些男女适合做夫妻 股市婉若深也可测的海洋 羽化的回忆 2016年街道总工会工作计划 会议管理要领 五分钱的梦想 快递快递,无所不递 《小时代3》刺金时代经典语录 小女孩儿(小说) 我的心路历程550字 春姑娘悄悄地来了作文300字 电力企业员工队伍建设的思考心得 职初教师培训心得体会 后浪 选择快乐作文400字 沙漠深处 小学五年级作文650字:不愿接起的电话 走出本市的儒雅书生 法国留学人员回国证明 生在这个时代 重庆三游洞导游词 石榴树 国家税务局上半年工作总结 运动会记事作文750字 那一次,我读懂了人生作文 真情唯汝一往而深---未尽的情书 表白情书:许我此生遇见你 高中高三作文600字:当人是兽时,他比兽还坏 走近初三 鲁迅在我心中作文800字 新农村建设中增加农民收入问题的思考 生活忧伤的句子 三件法宝助我考入北大 你有什么资格不努力 学习工会手册心得体会 2016出纳的工作总结怎么写 爱你的花,水仙花 工程师个人工作总结1000字 渐失的苗山之巢 寒假总结作文500字 我爱《品水浒》作文800字 2015省道德模范事迹材料 山东省潍坊市2006年中考语文试卷

Copyright © 2016 phpStudy |