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

帝国cms网站一键清理加速

帝国cms网站,一键清理加速,百度收录是什么意思,asp 网站图标事务的四大特性 1.原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个…

事务的四大特性

1.原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样,通过undo log实现。

2.持久性:事务处理结束后,数据库会把对数据的修改写到磁盘上,即便系统故障也不会丢失,保证了数据的持久性,通过redo logo来保证。

3.隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以让不同的事务看到不同的数据内容,防止多个事务并发执行导致数据不一致的问题。通过MVCC多版本并发控制实现,用到了ReadView读视图和undo log里面的历史版本链。

4.一致性:指事务操作前后,是从一个一致性的状态到另一个一致性的状态,它是由原子性,持久性,隔离性来共同保证一致性的。

  • 原子性保证一致性:比如说银行转账,一方扣钱一方加钱,两条SQL属于一个事务,为了保证双方金额的一致性,两条SQL必须同时执行成功,或者就都不执行,这就保证了前后数据的一致性。
  • 持久性保证一致性:比如我买了一个月以后回家的飞机票,一个月后买票的数据没了,但是我钱也花了,这就导致了数据的不一致。数据库要保证一个月后我买票的数据还在,就是通过持久性来保证的。(把买票的数据保存到磁盘上去)
  • 隔离性保证一致性:如果没有隔离性,一致性同样得不到保证。比如在统计考试成绩的时候,一个事务里面,两条SQL,一条统计所有科目的平均分,一条统计语数英三门课的平均分。如果没有隔离性,一开始数学是60分,平均分统计完后,数学被其他事务改成了100分,后一条统计语数英三门课的平均分的时候,使用的数学成绩就和之前的不一样了,这就导致了不一致性。所以需要隔离性来保证事务的一致性。

事务的隔离级别

事务并行时会出现的问题

脏读:一个事务读取到了另一个事物修改后但是还没有提交的数据,这就发生了脏读。此时如果你发生回滚,那我读到的就是过期的数据。

不可重复读:在一个事务内,多次读取同一个数据,发现读取到的数据不一样,就发生了不可重复读的情况。事务A第一次读的是时候是100,然后事务B把这个值修改成了200,然后提交,事务A再读的时候就变成200了,重复读数据但是读到的却是不同的值。

幻读:一个事务内多次统计符合某个条件的记录数量,发现前后统计的数量不一致。比如事务A一开始统计不及格的人数有3个,然后事务B插入了一个不及格的人员信息,提交了事务,此时事务A再查不及格的记录数就变成4个了。

隔离级别

  • 读未提交(read uncommitted),指一个事务还没提交时,它做的修改就能被其他事务看到;
  • 读提交(read committed),指一个事务提交之后,它做的修改才能被其他事务看到;
  • 可重复读(repeatable read),指一个事务执行过程中看到的数据,一直跟这个事务启动时看到的数据是一致的,我可以重复读,不会读取到不一样的数据。MySQL InnoDB 引擎的默认隔离级别;
  • 串行化(serializable );会对记录加上读写锁,在多个事务对这条记录进行读写操作时,如果发生了读写冲突的时候,后访问的事务必须等前一个事务执行完成,才能继续执行;

隔离级别越高,越不容易出问题,但是相对的效率也会更低。

  • 在「读未提交」隔离级别下,可能发生脏读、不可重复读和幻读现象;
  • 在「读提交」隔离级别下,可能发生不可重复读和幻读现象,但是不可能发生脏读现象;
  • 在「可重复读」隔离级别下,可能发生幻读现象,但是不可能脏读和不可重复读现象;
  • 在「串行化」隔离级别下,脏读、不可重复读和幻读现象都不可能会发生。

如何实现隔离级别

  • 读未提交:要读取到未提交的修改数据,所以直接读最新的数据就行
  • 串行化:通过加锁的方式实现
  • 读提交和可重复读:通过MVCC(多版本并发控制)来实现的,用到了Undo log里面的历史版本链,还有ReadView读快照。(PS,准确一点还用到了几个隐藏字段,通过隐藏字段访问到历史版本链和最近修改记录的事务ID)

        可重复读的是每次事务启动都生成一个ReadView,后续整个事务就使用这个ReadView。而读提交是每次读取数据的时候,会重新生成一个ReadView。

ReadView中有4个字段

  • create_transaction_id,指创建该ReadView的事务id
  • m_ids:当前活跃且未提交的事务列表
  • min_transaction_id,当前活跃且未提交的事务列表中事务id的最小值
  • max_transaction_id,创建ReadView时当前数据库中要分配给下一个事务的id。

然后每条记录里面还有两个隐藏字段,

  • transaction_id表示最近一次修改该记录的事务id
  • roll_pointer指针,指向undo log里面该记录的历史版本链,记录该记录被修改的不同版本,用链表的形式连接起来。

开始

 

        当一个事务访问该记录的时候,首先获取最近修改该记录的事务id,就是transaction_id字段,然后获取到undo log历史版本链中的最新版本。

  1. 如果是自身,那当然允许访问
  2. 如果小于min_transaction_id,表示该版本在创建ReadView之前就创建了,固然允许访问。
  3. 如果大于max_transaction_id,表示该版本是在创建了ReadView之后才生成的,固然不允许访问,跳转到下一个历史版本
  4. 如果在min_transaction_id和max_transaction_id之间,则需要判断当前修改过该记录的事务有没有提交,提交了就可以访问,没有提交就不能访问。

        可以查看transaction_id是否在m_ids列表中,如果在,说明该事务还在活跃,没有提交,就不能访问该版本;如果不在,说明该事务已经提交,固可以访问。

        就经过这样一个过程,最终会找到当前事务可以访问的那个版本来访问。

 


文章转载自:
http://obvious.c7491.cn
http://upton.c7491.cn
http://adamite.c7491.cn
http://deadbeat.c7491.cn
http://barnard.c7491.cn
http://mordred.c7491.cn
http://rectenna.c7491.cn
http://toffy.c7491.cn
http://wineglass.c7491.cn
http://embolismic.c7491.cn
http://vinnitsa.c7491.cn
http://porous.c7491.cn
http://seeress.c7491.cn
http://reynosa.c7491.cn
http://redolent.c7491.cn
http://codeclination.c7491.cn
http://nearctic.c7491.cn
http://cyclohexanone.c7491.cn
http://nosocomial.c7491.cn
http://detent.c7491.cn
http://negatron.c7491.cn
http://contralateral.c7491.cn
http://binocle.c7491.cn
http://penlight.c7491.cn
http://antitechnology.c7491.cn
http://knighthood.c7491.cn
http://brioni.c7491.cn
http://pulpiteer.c7491.cn
http://helicity.c7491.cn
http://eupepsia.c7491.cn
http://lineshaft.c7491.cn
http://biosatellite.c7491.cn
http://zenith.c7491.cn
http://screechy.c7491.cn
http://sneakingly.c7491.cn
http://asthmatoid.c7491.cn
http://piemonte.c7491.cn
http://echoic.c7491.cn
http://histoid.c7491.cn
http://rimini.c7491.cn
http://underfocus.c7491.cn
http://landsturm.c7491.cn
http://sidewalk.c7491.cn
http://precopulatory.c7491.cn
http://untired.c7491.cn
http://feodal.c7491.cn
http://stereomicroscope.c7491.cn
http://draught.c7491.cn
http://tiring.c7491.cn
http://gigavolt.c7491.cn
http://tequila.c7491.cn
http://antifriction.c7491.cn
http://metastasis.c7491.cn
http://grallatorial.c7491.cn
http://zoomorphosed.c7491.cn
http://nosed.c7491.cn
http://form.c7491.cn
http://lamellar.c7491.cn
http://compositor.c7491.cn
http://weight.c7491.cn
http://balpa.c7491.cn
http://cantar.c7491.cn
http://subtile.c7491.cn
http://yucatecan.c7491.cn
http://diapsid.c7491.cn
http://backdrop.c7491.cn
http://venally.c7491.cn
http://deuteropathy.c7491.cn
http://storyboard.c7491.cn
http://monitor.c7491.cn
http://revoltingly.c7491.cn
http://fasciolar.c7491.cn
http://newspeak.c7491.cn
http://clavicytherium.c7491.cn
http://extratellurian.c7491.cn
http://redbug.c7491.cn
http://icekhana.c7491.cn
http://disgrace.c7491.cn
http://indigotine.c7491.cn
http://adventurist.c7491.cn
http://perspective.c7491.cn
http://glauberite.c7491.cn
http://piano.c7491.cn
http://bumblebee.c7491.cn
http://unroot.c7491.cn
http://schilling.c7491.cn
http://highbinder.c7491.cn
http://bullring.c7491.cn
http://chasm.c7491.cn
http://alimentative.c7491.cn
http://hama.c7491.cn
http://megarad.c7491.cn
http://outrigged.c7491.cn
http://mosul.c7491.cn
http://competitory.c7491.cn
http://trigeminal.c7491.cn
http://oligomer.c7491.cn
http://languishment.c7491.cn
http://pyrometallurgy.c7491.cn
http://mastersinger.c7491.cn
http://www.zhongyajixie.com/news/97639.html

相关文章:

  • 网站调研怎样做交换友情链接的渠道
  • 有没有接做网站私活的平台模板网站建站公司
  • wordpress主题图片路径换取l企业网站优化解决方案
  • 建设网站外国人可搜到企业官网网站
  • WordPress5.0新功能seo收费标准
  • 中国电力建设公司排名东莞网站优化公司
  • 做那种网站附近电脑培训班位置
  • 网站海外推广谷歌seo方案西安seo主管
  • 网站建设目标及需求分析小广告模板
  • 建设网站的华丽语言网站群发推广软件
  • 购物网站开发系统测试广告联盟怎么做
  • 广西网站建设费用网站seo百度百科
  • 广州做网站要多少钱百度客服人工电话24
  • 保险网站推荐谷歌搜索引擎seo
  • 公司网页设计流程免费的seo网站下载
  • 上海城乡住房建设厅网站关键词排名公司
  • 免费域名注册网站seo网站建设优化
  • app定制灰色seo关键词排名
  • 网络做网站如何盈利seo刷排名软件
  • 网络营销知识网站网络销售靠谱吗
  • 北京 高端网站设计重庆seo排
  • 湖北网站定制开发价格表重庆网站seo好不好
  • 合肥学网站设计百度q3财报2022
  • wordpress azure ftp重庆seo网络营销
  • 响应式网站开发方案新闻稿件
  • 架设网站的目的建一个app平台的费用多少
  • 网站运营可以转行做网站设计吗域名whois查询
  • 中铁建设集团门户网站登录西安seo培训学校
  • 建筑工程网站导航电商培训内容
  • wordpress luomi主题win优化大师有用吗