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

网站建设 成本新手怎么做网络推广

网站建设 成本,新手怎么做网络推广,中国世界500强排名一览表,2022建站市场多版本并发控制(MVCC)是一种用于数据库并发控制的机制,它可以在保证数据一致性的同时,提高数据库的并发性能。下面结合 MVCC 机制,详细阐述常见的四种事务隔离级别(读未提交、读已提交、可重复读、串行化&a…

多版本并发控制(MVCC)是一种用于数据库并发控制的机制,它可以在保证数据一致性的同时,提高数据库的并发性能。下面结合 MVCC 机制,详细阐述常见的四种事务隔离级别(读未提交、读已提交、可重复读、串行化)与各种锁(共享锁、排他锁、记录锁、间隙锁、临键锁)之间的关系。

读未提交(Read Uncommitted)

  • MVCC 机制:在该隔离级别下,MVCC 机制基本不发挥作用。因为此隔离级别允许一个事务读取另一个未提交事务的数据,它更侧重于提高并发性能,而不是通过 MVCC 来保证数据的一致性。事务在读取数据时,不会基于 MVCC 去判断数据版本,而是直接读取最新的数据,无论该数据是否已经提交。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 此隔离级别对锁的使用进行了极大程度的弱化。一般情况下,普通的读操作不会加共享锁,写操作(如 UPDATEDELETEINSERT)虽可能会对受影响的行加排他锁,但这种锁的限制作用相对较弱,因为即使有排他锁存在,其他事务也能读取未提交的数据,会导致脏读。
  • 记录锁、间隙锁和临键锁
    • 通常不会使用记录锁、间隙锁和临键锁。由于不依赖 MVCC 来保证数据一致性,也不需要这些锁来防止不可重复读和幻读问题。

读已提交(Read Committed)

  • MVCC 机制:MVCC 在该隔离级别中发挥重要作用。普通的 SELECT 查询采用快照读,基于 MVCC 读取已提交的数据版本。每个语句执行时,都会生成一个新的快照,这使得在同一个事务内不同时刻执行相同的查询可能会得到不同的结果,从而可能出现不可重复读的问题。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通的 SELECT 查询默认不会加共享锁,而是利用 MVCC 进行快照读。但当使用 SELECT ... LOCK IN SHARE MODE 时,会对查询结果集的行加共享锁,允许其他事务同时读取这些行,但阻止其他事务对这些行加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句以及 SELECT ... FOR UPDATE 会对受影响的行加排他锁。并且,这些锁是语句级别的,即锁只在语句执行期间有效,语句执行完毕后锁就会释放。
  • 记录锁、间隙锁和临键锁
    • 记录锁:在执行 SELECT ... FOR UPDATE 或写操作时,会对读取或修改的行加记录锁。
    • 间隙锁和临键锁:一般不会使用间隙锁和临键锁。因为 MVCC 的快照读机制和语句级别的锁控制,使得该隔离级别允许幻读的存在,无法阻止其他事务在查询范围的间隙插入新记录。

可重复读(Repeatable Read)

  • MVCC 机制:MVCC 是该隔离级别实现可重复读特性的关键。在事务开始时,会创建一个全局的快照,事务内的所有 SELECT 查询都基于这个快照进行,保证在同一个事务内多次读取相同数据的结果是一致的。不过,对于当前读操作(如 SELECT ... FOR UPDATEUPDATEDELETE),MVCC 机制与锁机制共同作用来保证数据的一致性。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通 SELECT 查询采用快照读,不会加共享锁。使用 SELECT ... LOCK IN SHARE MODE 时,会对查询结果集的行加共享锁,防止其他事务对这些行加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句以及 SELECT ... FOR UPDATE 会对受影响的行加排他锁。这些锁会在事务结束(提交或回滚)时才释放。
  • 记录锁、间隙锁和临键锁
    • 记录锁:在执行 SELECT ... FOR UPDATE 或写操作时,会对读取或修改的行加记录锁。
    • 间隙锁:当进行范围查询(如 SELECT ... FOR UPDATE 或写操作涉及范围条件)且查询条件没有精确匹配到所有记录时,会对查询范围对应的间隙加上间隙锁,防止其他事务在这些间隙插入新记录。这是为了弥补 MVCC 在处理范围插入时可能出现幻读的不足。
    • 临键锁:临键锁是记录锁和间隙锁的组合。在可重复读隔离级别下,对于索引记录,InnoDB 通常使用临键锁来防止幻读。例如,对唯一索引进行等值查询时,如果记录存在,使用记录锁;如果记录不存在,使用间隙锁;对于普通索引,一般使用临键锁。

串行化(Serializable)

  • MVCC 机制:在串行化隔离级别下,MVCC 机制基本不发挥作用。因为该隔离级别要求事务串行执行,所有的读写操作都需要排队进行,以保证数据的绝对一致性。它不依赖 MVCC 的多版本特性来处理并发,而是通过严格的锁机制来实现事务的隔离。
  • 共享锁(S 锁)和排他锁(X 锁)
    • 共享锁:普通的 SELECT 查询会自动对查询结果集的行加共享锁,保证在当前事务读取数据期间,其他事务不能对这些数据加排他锁进行修改。
    • 排他锁UPDATEDELETEINSERT 语句会自动对受影响的行加排他锁。由于事务是串行执行的,任何事务的读写操作都需要等待前面事务释放相应的锁,并发性能最差,但能完全避免脏读、不可重复读和幻读问题。
  • 记录锁、间隙锁和临键锁
    • 在串行化隔离级别下,记录锁、间隙锁和临键锁都会被使用,以确保事务之间的完全隔离。无论是读取还是修改数据,都会通过这些锁来保证同一时间只有一个事务可以访问特定的数据资源,从而实现事务的串行执行。

综上所述,MVCC 机制和锁机制在不同的事务隔离级别中相互配合,共同影响着数据库的并发性能和数据一致性。较低的隔离级别更依赖 MVCC 来提高并发性能,而较高的隔离级别则更强调锁机制来保证数据的严格一致性。

http://www.tj-hxxt.cn/news/123613.html

相关文章:

  • 建设网站安全措施百度竞价广告怎么投放
  • 网站建设服务好公司广州seo成功案例
  • 采网站建设搜索历史记录
  • 网站有哪些区别是什么培训优化
  • 微信h5商城网站开发网站排名优化
  • 网站开发流程图seo网站推广案例
  • 如何做阿里详情页面链接到外部网站烟台seo外包
  • 网站seo跟短视频新平台怎么推广
  • 做游戏网站多钱如何刷关键词指数
  • 简述网站开发平台官网优化 报价
  • 网站做子站点有什么用武汉seo人才
  • 定制鞋子哪个网站好app开发自学教程
  • 类似有点料的推广平台seo上海优化
  • ps做游戏网站免费做网站软件
  • 网站推广策划方案模板seo案例分析
  • 怎样做微商网站如何在百度上做广告
  • 合肥高端网站91手机用哪个浏览器
  • wordpress建站镜像事件营销的概念
  • 晋中企业网站建设公司网址收录
  • 做网站 传视频 用什么笔记本好app推广是什么工作
  • 动态网站标题怎么做的湖南网站seo找行者seo
  • 西安百度公司开户seo新手教程
  • 视频网站建设框架百度下载app下载
  • 做营销型网站 公司seo关键词外包
  • wordpress站内seo百度云
  • 深圳网站设计 建设首选深圳市徐州关键词优化排名
  • 开发一个大型网站多少钱seo在线优化
  • 网站出现的问题seo关键词有话要多少钱
  • 南宁高端网站建设公司电池优化大师下载
  • 河南省建设劳动学会网站企业网站推广优化