zoukankan      html  css  js  c++  java
  • MySQL MVCC专题

    什么是MVCC

    独占锁(排它锁),也成X锁(Exclusive Lock):独占锁锁定的资源只允许进行锁定操作的程序使用,其他任何对它的操作均不会被接受。执行数据更新命令:即Insert、UPDATE或Delete命令时,MySQL会自动使用独占锁,但当对象上有其它锁存在时,无法对其加独占锁,独占锁一直到事物结束才能被释放。

    共享锁,也叫S锁(Share Lock :那就是锁定的资源可以被其他用户读取,但其他用户不能修改,如果select查询语句要手动加人共享锁。那么对应的SQL语句:Select ... lock in share mode

    表锁:**操作对象是数据表。Mysql大多数锁策略都支持,是系统开销最低但并发性最低的一个锁策略。事务t对整个表加读锁,则其他事务可读不可写,若加写锁,则其他事务增删改都不行。

    行级锁:操作对象是数据表中的一行。是MVCC技术用的比较多的。行级锁对系统开销较大,但处理高并发较好。

    MVCC使得大部分支持行锁的事务引擎,不再单纯的使用行锁来进行数据库的并发控制,取而代之的是把数据库的行锁与行的多个版本结合起来,只需要很小的开销,就可以实现非锁定读,从而大大提高数据库系统的并发性能。

    DATA_TRX_ID:用来标识最近一次对本行记录做记录(insert/update)事务的标识符,即最后一次修改本行记录的事务id

    DATA_ROLL_PTR:指写入回滚段(rollback segment)的 undo log record (撤销日志记录记录)。如果一行记录被更新, 则 undo log record 包含 '重建该行记录被更新之前内容' 所必须的信息。

    InnoDB的MVCC,是通过在每行纪录后面保存两个隐藏的列来实现的。这两个列,一个保存了行的创建时间一个保存了行的过期时间(或删除时间),当然存储的并不是实际的时间值,而是系统版本号。每开始一个新的事务,系统版本号都会自动递增。事务开始时刻的系统版本号会作为事务的版本号,用来和查询到的每行纪录的版本号进行比较

    1.MVCC手段只适用于Msyql隔离级别中的读已提交(Read committed)和可重复读(Repeatable Read).

    2.Read uncimmitted由于存在脏读,即能读到未提交事务的数据行,所以不适用MVCC.

    原因是MVCC的创建版本和删除版本只要在事务提交后才会产生。

    3.串行化由于是会对所涉及到的表加锁,并非行锁,自然也就不存在行的版本控制问题。

    4.通过以上总结,可知,MVCC主要作用于事务性的,有行锁控制的数据库模型。`

  • 相关阅读:
    python中的一些小知识
    软件工程第一次作业(2)
    CountDownLatch的理解和使用
    架构设计:系统间通信(1)概述从“聊天”开始上篇
    Asp默认的上传文件大小限制是200K
    当多个sqlserver服务存在时,需要完全限定的serverName 方可登陆
    关于Entity Framework 版本的疑惑
    mvc scaffolding
    sql 语句中的 NULL值
    如何从数据库生成 EF Code First model
  • 原文地址:https://www.cnblogs.com/shine-rainbow/p/12494825.html
Copyright © 2011-2022 走看看