城市直播房产教育博客汽车
汽车报价
买车新车
博客专栏
专题精品
教育留学
高考读书
房产家居
彩票视频
直播黑猫
投资微博
城市上海
政务旅游

一文详解MySQL事务和锁

10月22日 辞凤阙投稿
  事务概述
  当多个用户访问同一份数据时,一个用户在更改数据的过程中,可能有其他用户同时发起更改请求,为保证数据库记录的更新从一个一致性状态变为另外一个一致性状态,使用事务处理是非常必要的,事务具有以下四个特性:原子性(Atomicity):事务中所有操作视为一个原子单位,即对事务所进行的数据修改等操作只能是完全回滚或完全提交一致性(Consistency):事务在完成时,必须使用所有的数据从一种一致性变更为另一种一致性状态,所有的变更都必须应用于事务的修改,以确保数据的完整性。事务的一致性由原子性、持久性和隔离性一起实现隔离性(Isolation):一个事务中的操作语句所做的修改必须与其他事务所做的修改相隔离。在进行事务查看数据时,数据所处的状态,要么是被另一个并发事务修改之前的状态,要么是被另一并发事务修改之后的状态,即当前事务不会查询由另一个并发事务正在修改的数据。隔离性由MySQL锁机制实现持久性(Durability):事务完成之后,所做的修改对数据的影响是永久的,即使系统重启或者出现系统故障,数据仍可恢复
  MySQL提供了多种事务型存储引擎,如InnoDB和BDB等,而MyISAM不支持事务。为了支持事务,InnoDB存储引擎引入了与事务处理相关的REDO日志和UNDO日志,同时事务依赖于MySQL提供的锁机制1。REDO日志
  事务执行时需要将执行的事务日志写入日志文件,对应的文件为REDO日志。当每条SQL进行数据更新操作时,首先将REDO日志写进日志缓冲区。当客户端执行COMMIT命令提交时,日志缓冲区的内容将被刷新到磁盘,日志缓冲区的刷新方式或者时间间隔可以通过参数innodbflushlogattrxcommit控制
  REDO日志对应磁盘上的iblogifleN文件,该文件默认为5MB,建议设置为512MB,以便容纳较大的事务。MySQL崩溃恢复时会重新执行REDO日志的记录,恢复最新数据,保证已提交事务的持久性2。UNDO日志
  与REDO日志相反,UNDO日志主要用于事务异常时的数据回滚,具体内容就是记录数据被修改前的信息到UNDO缓冲区,然后在合适的时间将内容刷新到磁盘
  假如由于系统错误或者rollback操作而导致事务回滚,可以根据undo日志回滚到没修改前的状态,保证未提交事务的原子性
  与REDO日志不同的是,磁盘上不存在单独的UNDO日志文件,所有的UNDO日志均存在表空间对应的。ibd数据文件中,即使MySQL服务启动了独立表空间事务控制语句
  在MySQL中,可以使用BEGIN开始事务,使用COMMIT结束事务,中间可以使用ROLLBACK回滚事务。MySQL通过SETAUTOCOMMIT、STARTTRANSACTION、COMMIT和ROLLBACK等语句支持本地事务STARTTRANSACTIONBEGIN〔WORK〕COMMIT〔WORK〕ROLLBACK〔WORK〕SETAUTOCOMMIT{01}BEGINSTARTTRANSACTION:开始事务COMMIT:结束事务ROLLBACK:回滚事务WORK:SQL语句SETAUTOCOMMIT:是否自动提交,0禁止,1开启,默认为1事务隔离级别
  MySQL定义了四种隔离级别,指定事务中哪些数据改变其他事务可见、哪些数据该表其他事务不可见。低级别的隔离级别可以支持更高的并发处理,同时占用的系统资源更少
  InnoDB系统级事务隔离级别可以使用以下语句设置:SETGLOBALTRANSACTIONISOLATIONLEVELREADUNCOMMITTED;SETGLOBALTRANSACTIONISOLATIONLEVELREADCOMMITTED;SETGLOBALTRANSACTIONISOLATIONLEVELREPEATABLEREAD;SETGLOBALTRANSACTIONISOLATIONLEVELSERIALIZABLE;
  查看系统级事务隔离级别:SELECTglobal。
  InnoDB会话级事务隔离级别可以使用以下语句设置:SETSESSIONTRANSACTIONISOLATIONLEVELREADUNCOMMITTED;SETSESSIONTRANSACTIONISOLATIONLEVELREADCOMMITTED;SETSESSIONTRANSACTIONISOLATIONLEVELREPEATABLEREAD;SETSESSIONTRANSACTIONISOLATIONLEVELSERIALIZABLE;
  查看会话级事务隔离级别:SELECT1。读未提交
  在该隔离级别,所有事务都可以看到其他未提交事务的执行结果。读取未提交的数据称为脏读(DirtyRead),即是:首先开启A和B两个事务,在B事务更新但未提交之前,A事务读取到了更新后的数据,但由于B事务回滚,导致A事务出现了脏读现象2。读已提交
  所有事务只能看见已经提交事务所做的改变,此级别可以解决脏读,但也会导致不可重复读(NonrepeatableRead):首先开启A和B两个事务,A事务读取了B事务的数据,在B事务更新并提交后,A事务又读取到了更新后的数据,此时就出现了同一A事务中的查询出现了不同的查询结果3。可重复读
  MySQL默认的事务隔离级别,能确保同一事务的多个实例在并发读取数据时看到同样的数据行,理论上会导致一个问题,幻读(PhontomRead)。例如,第一个事务对一个表中的数据做了修改,这种修改会涉及表中的全部数据行,同时第二个事务也修改这个表中的数据,这次的修改是向表中插入一行新数据,此时就会发生操作第一个事务的用户发现表中还有没有修改的数据行
  InnoDB通过多版本并发控制机制(MVCC)解决了该问题:InnoDB通过为每个数据行增加两个隐含值的方式来实现,这两个隐含值记录了行的创建时间、过期时间以及每一行存储时间发生时的系统版本号,每个查询根据事务的版本号来查询结果4。串行化
  通过强制事务排序,使其不可能相互冲突,从而解决幻读问题。简而言之,就是在每个读的数据行上加上共享锁实现,这个级别会导致大量的超时现象和锁竞争,一般不推荐使用InnoDB锁机制
  为了解决数据库并发控制问题,如走到同一时刻客户端对同一张表做更新或者查询操作,需要对并发操作进行控制,因此产生了锁1。锁的类型1。1共享锁
  共享锁的粒度是行或者元组(多个行),一个事务获取了共享锁以后,可以对锁定范围内的数据执行读操作1。2排他锁
  排他锁的粒度与共享锁相同,一个事务获取排他锁以后,可以对锁定范围内的数据执行写操作
  有两个事务A和B,如果事务A获取了一个元组的共享锁,事务B还可以立即获取这个元组的共享锁,但不能获取这个元组的排他锁,必须等到事务A释放共享锁之后。如果事务A获取了一个元组的排他锁,事务B不能立即获取这个元组的共享锁,也不能立即获取这个元组的排他锁,必须等到A释放排他锁之后1。3意向锁
  意向锁是一种表锁,锁定的粒度是整张表,分为意向共享锁和意向排他锁。意向共享锁表示一个事务有意对数据上共享锁或者排他锁。有意表示事务想执行操作但还没真正执行2。锁的粒度
  锁的粒度主要分为表锁和行锁
  表锁的开销最小,同时允许的并发量也是最小。MyISAM存储引擎使用该锁机制。当要写入数据时,整个表记录被锁,此时其他读写动作一律等待。一些特定的动作,如ALTERTABLE执行时使用的也是表锁
  行锁可以支持最大的并发,InnoDB存储引擎使用该锁机制。如果要支持并发读写,建议采用InnoDB存储引擎
  原文链接:https:www。cnblogs。comYeeQp16209147。html?utmsourcetuicoolutmmediumreferral
搜索 投诉 评论 转载

这种化工新材料成了香饽饽!神马股份7亿元布局一、神马股份7亿元布局高性能对位芳纶10月29日,神马股份发布公告称,拟在河南省平顶山市尼龙新材料产业集聚区设立全资子公司河南神马芳纶技术开发有限公司(以工商登记机关核准……花呗的套路被发现?多数年轻人纷纷选择关闭花呗,原因是啥?我用了五年多的花呗,也没发现什么套路啊?反正我是按时还钱的,没啥问题,一切正常。有什么套路?以为花呗不是自己的钱随便用?我用来网上交易的卡放很少的钱,怕出问题,有时……苹果耳机音质能达到什么水平?作为一个入坑苹果多年的人,用过的iPhone从iPhone4到iPhoneX一代都没落下,随机附送的耳机,也一直是我的听歌主力。所以我个人觉得,这种问题我最有发言权,不过随机附……小鹏汽车荣膺2022年度德国iF设计三项用户体验大奖F设计奖创立于1954年,由德国历史最悠久的工业设计机构汉诺威工业设计论坛每年定期评选,其以独立、严谨、可靠的评奖理念闻名于世,与德国红点奖、IDEA美国杰出工业设计奖并称为世……字节跳动发大事记怒批腾讯三年封禁近17次,还打了30余次官司6月4日下午,字节跳动在其官方微信上发了一篇字节跳动遭遇腾讯屏蔽和封禁大事记(20182021)的文章。文章中罗列了字节跳动在过去三年被腾讯封禁17次,而双方还打了30余次官司……一文详解MySQL事务和锁事务概述当多个用户访问同一份数据时,一个用户在更改数据的过程中,可能有其他用户同时发起更改请求,为保证数据库记录的更新从一个一致性状态变为另外一个一致性状态,使用事务处理……芯片专家大量外出,未来该如何留住人才?给予人才比国外更优质的待遇没有爱国精神中国作为全世界最大的制造业中心,包揽着全球36的电子产品生产制造。其中,中国也是全球第二大的嵌入式芯片电子设备消费市场,中国生……元宇宙再次迎来利好,盘点八大黑马龙头公司元宇宙行业前景光明,目前尚处于行业的导入期,2021年是元宇宙的元年,随着互联网巨头Facebook、苹果、阿里百度的加速布局,元宇宙行业会加速渗透。最近的两大利好消息是……时势造英雄,朋克时代的到来,由朋克多多开始微型电动车正驶入发展的快车道。今年一季度,国内纯电动汽车累积销量达到359704辆,其中,小型新能源乘用车表现亮眼,以40。2的占比高居第一。这也意味着,当下每卖出10台……90万奖池!思必驰助力英特尔大师挑战赛携手网鱼竞技场高燃开战今夏,全民电竞如期而至!5月14日起,2021英特尔大赛挑战赛网咖及电竞酒店联赛第三赛季暨网鱼竞技场英雄联盟挑战赛开放报名。网鱼网咖80多座城市的超900家门店吹响号角。总奖池……能当望远镜使用的三款手机,第一款买不起,第三款超出预期最近,一条拍摄月亮的视频彻底火了,很多刷到这条视频的人都会有一个疑问,这款所谓菠萝20的手机,到底是何方神圣,尽然能把月亮上的环形山都拍得一清二楚?接下来,笔者就带大家一起来分……外媒拆解iPhone13Pro硬件总成本出炉,降价的原因找到iPhone的售价远高于安卓手机,iPhone13系列虽然降价,最低售价也在5000元以上,超出了不少用户的购机预算。都知道苹果的利润非常高,因此每年的新款iPhone上市后,……
初探初中学生数学解题误区基于人口统计学变量的非伦理消费行为国内体育微课研究现状及趋势分析细谈纳米TiO2对大豆蛋白聚乙烯醇复合薄膜的影响研究论文学科建设下的科研管理信息化平台构建论文我国现代文学精神解读浅析小学低龄儿童音乐感知力的开发高职英语教学职业化研究论文浅谈如何实现医院档案管理信息化网络表达自由的规制机制研究戏曲个性丧失的忧虑(1)网络防御技术论文范文
产生岩爆的决定性因素我喜欢的一堂课作文400字露天烧烤产生的烟气有哪些危害小学生关于夏至节气的谚语积累修车老人尾田荣一郎(休刊100多次的尾田荣一郎)热传聚热点网 有赞首席运营官浣昉:“悦己”消费突出,线上消费仍保持增长观察植物日记五则在我国房屋转租要交房产税吗家庭暴力存在哪些特点面对别人的嘲笑,孩子不会面对怎么办?专家用爱引导孩子成长心病

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找江西南阳嘉兴昆明铜陵滨州广东西昌常德梅州兰州阳江运城金华广西萍乡大理重庆诸暨泉州安庆南充武汉辽宁