当前位置: 首页 > news >正文

东莞专业做网站公司视觉传达设计培训机构有哪些

东莞专业做网站公司,视觉传达设计培训机构有哪些,网站ie浏览器不兼容,合作seo公司什么是事务 事务是由数据库中一系列的访问和更新组成的逻辑执行单元 事务的逻辑单元中可以是一条SQL语句,也可以是一段SQL逻辑,这段逻辑要么全部执行成功,要么全部执行失败 举个最常见的例子,你早上出去买早餐,支付…

什么是事务

事务是由数据库中一系列的访问和更新组成的逻辑执行单元

事务的逻辑单元中可以是一条SQL语句,也可以是一段SQL逻辑,这段逻辑要么全部执行成功,要么全部执行失败

举个最常见的例子,你早上出去买早餐,支付宝扫码付款给早餐老板,这就是一个简单的转账过程,会包含两步

从你的支付宝账户扣款10元
早餐老板的账户增加10元

这两步其中任何一部出现问题,都会导致整个账务出现问题

假如你的支付宝账户扣款10元失败,早餐老板的账户增加成功,那你就Happy了,相当于马云请你吃早餐了,O(∩_∩)O哈哈~

假如你的支付宝账户扣款10元成功,早餐老板的账户增加失败,那你就悲剧了,早餐老板不会放过你,会让你重新付款,相当于你请马云吃早餐了-_-?

事务就是用来保证一系列操作的原子性,上述两步操作,要么全部执行成功,要么全部执行失败

数据库为了保证事务的原子性和持久性,引入了redo log和undo log

redo log

redo log是重做日志,通常是物理日志,记录的是物理数据页的修改,它用来恢复提交后的物理数据页
在这里插入图片描述

如上图所示,redo log分为两部分:

内存中的redo log Buffer是日志缓冲区,这部分数据是容易丢失的
磁盘上的redo log file是日志文件,这部分数据已经持久化到磁盘,不容易丢失

SQL操作数据库之前,会先记录重做日志,为了保证效率会先写到日志缓冲区中(redo log Buffer),再通过缓冲区写到磁盘文件中进行持久化,既然有缓冲区说明数据不是实时写到redo log file中的,那么假如redo log写到缓冲区后,此时服务器断电了,那redo log岂不是会丢失?

在MySQL中可以自已控制log buffer刷新到log file中的频率,通过innodb_flush_log_at_trx_commit参数可以设置事务提交时log buffer如何保存到log file中,innodb_flush_log_at_trx_commit参数有3个值(0、1、2),表示三种不同的方式

为1表示事务每次提交都会将log buffer写入到os buffer,并调用操作系统的fsync()方法将日志写入log file,这种方式的好处是就算MySQL崩溃也不会丢数据,redo log file保存了所有已提交事务的日志,MySQL重新启动后会通过redo log file进行恢复。但这种方式每次提交事务都会写入磁盘,IO性能较差
为0表示事务提交时不会将log buffer写入到os buffer中,而是每秒写入os buffer然后调用fsync()方法将日志写入log file,这种方式在MySQL系统崩溃时会丢失大约1秒钟的数据
为2表示事务每次提交仅将log buffer写入到os buffer中,然后每秒调用fsync()方法将日志写入log file,这种方式在MySQL崩溃时也会丢失大约1秒钟的数据

undo log

undo log是回滚日志,用来回滚行记录到某个版本,undo log一般是逻辑日志,根据行的数据变化进行记录

undo log跟redo log一样也是在SQL操作数据之前记录的,也就是SQL操作先记录日志,再进行操作数据

在这里插入图片描述

总结一下

MySQL中是如何实现事务提交和回滚的?

为了保证数据的持久性,数据库在执行SQL操作数据之前会先记录redo log和undo log

redo log是重做日志,通常是物理日志,记录的是物理数据页的修改,它用来恢复提交后的物理数据页

undo log是回滚日志,用来回滚行记录到某个版本,undo log一般是逻辑日志,根据行的数据变化进行记录

redo/undo log都是写先写到日志缓冲区,再通过缓冲区写到磁盘日志文件中进行持久化保存

undo日志还有一个用途就是用来控制数据的多版本(MVCC)

简单理解就是:

redo log是用来恢复数据的,用于保障已提交事务的持久性

undo log是用来回滚事务的,用于保障未提交事务的原子性

http://www.yayakq.cn/news/608921/

相关文章:

  • 公司网站开发费用大概多少开公司的注意事项
  • 班级管理网站开发专业网站开发
  • 菏泽网站建设电话咨询镇江地区做网站的公司有哪些
  • 后台网站下载免费设计logo的手机软件
  • 哎吆嗨网站建设今天三河燕郊确诊名单
  • 做网站杭州傲视信息wordpress适应手机
  • 广州市照明建设管理中心网站无锡网站怎么优化排名
  • 贵阳市白云区官方网站泰安直聘网官网
  • 苍溪网站建设制作北京广告设计制作公司
  • 手机网站后台源码管理系统官方网站
  • 文化馆网站建设广告设计公司专业报价表
  • 深圳网站建设 骏域网站建设网站分享图片怎么做
  • 建设项目环境影响网站高端网站建设公司成都
  • 口碑好的定制网站建设提供商电子商务营销推广
  • 阿里万网怎么做网站郑州app网站公司
  • 源码猫网站建设ym361网络推广的具体方式
  • 大学学校类网站设计南京谁做免费网站
  • 高质量网站外链平台图片优化
  • 手机网站工具什么网站发布公司销售
  • 可用来做外链推广的网站宝塔如何搭建网站
  • page怎么打开wordpress网站的优化是什么意思
  • 怎么自己创建一个免费网站可以访问任何网站的浏览器
  • 为什么手机网站跳转页面上网站开发三层架构
  • 网站跳转怎么解释wordpress 劣势
  • 做电子商务网站多少钱专业制作标书
  • 开发网站流程myeclipse做网站的步骤
  • 搜索引擎网站分析电子商务网站开发的过程
  • 一般产地证去哪个网站做怎么用手机做刷会员网站
  • 郑州网站建设推销南宁网络公司设计
  • 企业网站的建设论文东道设计老板