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

软件公司网站建设2008vps做网站

软件公司网站建设,2008vps做网站,互联网 网站定制,苏州关键词优化怎样选择隔离级别的时候,既需要考虑数据的一致性,避免脏数据,又要考虑系统性能的问题。下面我们通过商品抢购的场景来讲述这4种隔离级别的区别 未提交读(read uncommitted) 未提交读是最低的隔离级别,其含义是…

选择隔离级别的时候,既需要考虑数据的一致性,避免脏数据,又要考虑系统性能的问题。下面我们通过商品抢购的场景来讲述这4种隔离级别的区别

未提交读(read uncommitted)

未提交读是最低的隔离级别,其含义是允许一个事务读取另一个事务没有提交的数据。未提交读是一种危险的隔离级别,所以在实际的开发中应用不广,但是它的优点在于并发能力高,适合那些对数据一致性没有要求而追求高并发的场景,它的最大坏处是可能发生脏读。表6-3展示了可能发生的脏读现象。

脏读现象

在这里插入图片描述
在表6-3所示的T3时刻,因为采用未提交读,所以事务2可以读取事务1未提交的库存1,事务2扣减库存后则库存为0,然后事务2提交事务,库存就变为了0,而事务1在T5时刻回滚事务,因为第一类丢失更新已经被克服,所以它不会将库存回滚到2,那么最后的库存就变为了0,这样就出现了错误。为了克服脏读的问题,数据库标准提供了读写提交的级别。

2. 读写提交(read committed)

读写提交隔离级别,是指一个事务只能读取另一个事务已经提交的数据,不能读取未提交的数据。例如,表6-3的场景在限制为读写提交隔离级别后,就变为表6-4描述的场景了。

               表6-4 克服脏读

在这里插入图片描述
在T3时刻,由于采用了读写提交的隔离级别,因此事务2读取不到事务1中未提交的库存2,T4时刻扣减库存的结果依旧为2,然后事务2提交事务,在T5时刻库存就变为了2。在T6时刻,事务1回滚,因为第一类丢失更新已经克服,所以最后库存为2,这是一个正确的结果。但是读写提交也会产生表6-5所描述的不可重复读现象。

                 表6-5 不可重复读现象

在这里插入图片描述
在T3时刻,事务2读取库存,因为事务1未提交事务,所以读出的库存为1,于是事务2认为当前可扣减库存。在T4时刻,因为事务1已经提交事务,所以在T5时刻,事务2扣减库存的时候就发现库存为0,于是就无法扣减库存了。这里的问题在于事务2之前认为可以扣减,而到扣减那一步却发现已经不可以扣减,于是库存对事务2而言是一个可变化的值,这样的现象称为不可重复读,这就是读写提交的一个不足之处。为了克服这个不足,数据库的标准还提供了可重复读的隔离级别,它能够克服不可重复读的问题

3. 可重复读(repeatable read)

可重复读的目标是克服读写提交中出现的不可重复读的现象,因为在读写提交的时候,可能出现一些值的变化,影响当前事务的运行,如上述的库存是一个变化的值。这个时候数据库标准提出了可重复读的隔离级别,能够克服不可重复读的问题,如表6-6所示。

                    表6-6 克服不可重复读

在这里插入图片描述
可以看到,事务2在T3时刻尝试读取库存,但是此时这个库存已经被事务1读取,所以这个时候数据库就阻塞事务2的读取,直至事务1提交,事务2才能读取库存的值。此时已经是T5时刻,而读取到的值为0,这时就已经无法扣减了,显然在读写提交中出现的不可重复读的现象被消除了。但是,这样做也会引发新的问题——幻读。假设现在商品交易正在进行中,而后台有人也在进行查询和打印的业务,让我们看看可能出现的场景,如表6-7所示。

						表6-7 幻读现象

在这里插入图片描述
这便是幻读现象。可重复读和幻读是读者比较难以理解的内容,这里简单解释一下。这里的交易记录数不是数据库存储的值,而是一个统计值,商品库存则是数据库存储的值,这一点是要注意的。也就是说,幻读是针对多条记录而言的,例如,T6时刻打印的51笔交易记录就是多条数据库记录。可重复读是针对数据库的一条记录而言的,例如,商品的库存是以数据库里面的一条记录存储的,它可以产生可重复读,而不能产生幻读。

串行化(serializable)

串行化是数据库最高的隔离级别,它会要求所有SQL语句都按照顺序运行,这样就可以克服上述隔离级别出现的各种问题,能够完全保证数据的一致性。

使用合理的隔离级别

						表6-8 隔离级别和可能发生的现象

在这里插入图片描述
作为互联网应用开发者,在开发高并发业务时需要时刻记住隔离级别的各种概念和可能发生的相关现象,这是数据库事务的核心内容,也是互联网企业关注的重要内容。在企业的生产实践中,选择隔离级别一般会以读写提交为主,它能够防止脏读,但不能避免不可重复读和幻读。为了克服数据不一致和性能问题,程序开发者还设计了乐观锁,甚至使用其他数据库,例如使用Redis作为数据载体。对于隔离级别,不同的数据库的支持也是不一样的。例如,racle只能支持读写提交和串行化,而MySQL则能够支持4种,racle默认的隔离级别为读写提交,MySQL默认的隔离级别则是可重复读。


文章转载自:

http://rG9b6J9r.gmmyt.cn
http://DYGEWG9M.gmmyt.cn
http://NJ1iqujA.gmmyt.cn
http://PMEmNBvl.gmmyt.cn
http://0ApwqkyS.gmmyt.cn
http://t0CqajuL.gmmyt.cn
http://ANXB7qxo.gmmyt.cn
http://no99qIUR.gmmyt.cn
http://5Ug5XIHD.gmmyt.cn
http://xEPX1Lz2.gmmyt.cn
http://ezL0rh8e.gmmyt.cn
http://eOnFq4Gt.gmmyt.cn
http://30J6aJdQ.gmmyt.cn
http://jH8DtYvk.gmmyt.cn
http://JOY9fjMV.gmmyt.cn
http://kzsOqs7e.gmmyt.cn
http://m9wAIEq9.gmmyt.cn
http://7Vcp72Ka.gmmyt.cn
http://ljSDYd0g.gmmyt.cn
http://CpBc6Gct.gmmyt.cn
http://G7v0heId.gmmyt.cn
http://yo4qMEXf.gmmyt.cn
http://Fl6czOsi.gmmyt.cn
http://VCaf06fC.gmmyt.cn
http://kIK7Li1j.gmmyt.cn
http://YgrsK0hI.gmmyt.cn
http://xCZbCMgw.gmmyt.cn
http://UzkuYAtu.gmmyt.cn
http://Et1E8e1L.gmmyt.cn
http://9pOpJhBx.gmmyt.cn
http://www.dtcms.com/wzjs/715283.html

相关文章:

  • 简单的网站怎么做集团有限公司成立条件
  • 做家教去哪个网站互联网营销师报名
  • 龙岗建网站公司wordpress 增加小工具
  • 百姓网网站建设网络营销外包平台
  • 做网站需要钱吗wordpress 微信抓取
  • 营销型网站深度网中国多少个省份31个省
  • 迅速编程做网站青岛做网站的大公司有
  • python网站开发框架怎样帮拍卖网站做策划
  • 网站制作设计说明手机支付网站开发
  • 网站开发怎么进行数据库连接石家庄网站快速排名
  • 网站无法处理请求商城网站建设报价方案
  • 闲鱼网站是哪家公司做的深圳贸易网站建设
  • 怎么做家具定制网站网站名称和网址
  • 网站建设技术支持蔡甸网站建设
  • 西安php网站开发培训班电脑优化是什么意思
  • 做网站公司的收费多少北辰天津网站建设
  • 网站平台多少钱山东省最新消息今天
  • 学校网站建设情况介绍会员系统免费版
  • 绵阳新农网的网站是哪个公司做的wordpress首页调用最新文章
  • 建设部网站在哪里看受理做名片上什么网站
  • 佛山顺德网站制作公司哪家好制作ppt的软件手机
  • 公司中英文网站锦绣大地seo
  • 江门专用网站建设建立选区的快捷键
  • 做爰全过程免费的视频网站有声音第四性 wordpress
  • 电商网站建设实训报告心得h5页面制作工具包括
  • 郑州网站建设包括哪些wordpress 开发 表单
  • 如何让公司网站网站建设公司固定ip
  • 钦州市建设网站php综合网站建设论文
  • 做网站卖产品网页制作和网站建设的区别
  • 电商主图设计网站温州在线课堂