• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >Mysql > MySQL数据库锁定机制的介绍

MySQL数据库锁定机制的介绍

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-05

匿名通过本文主要向大家介绍了mysql,锁等相关知识,希望本文的分享对您有所帮助
本篇文章给大家带来的内容是关于 MySQL数据库锁定机制的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

MySQL锁定机制简介

  1. 数据库锁定机制简单来说就是数据库为了保证数据的一致性而使各种共享资源在被并发访问变得有序所设计的一种规则。

  2. 对于任何一种数据库来说都需要有相应的锁定机制,所以MySQL自然也不例外。

  3. MySQL数据库由于其自身架构的特点,存在多种数据存储引擎,每种存储引擎所针对的应用场景特点都不太一样,为了满足各自特定应用场景的需求,每种存储引擎的锁定机制都是为各自所面对的特定场景而优化设计,所以,各种存储引擎的锁定机制也有较大区别。

  4. 总的来说,MySQL各存储引擎使用了三种类型(级别)的锁定机制:行级锁定,页级锁定和表级锁定。

行级锁定(row-level)

  1. 行级锁,一般是指排它锁,即被锁定行不可进行修改、删除,只可以被其他会话select。

  2. 排他锁又称为写锁,简称X锁,顾名思义,排他锁就是不能与其他锁并存,如一个事务获取了一个数据行的排他锁,其他事务就不能再获取该行的其他锁。

  3. 行级锁定最大的特点就是锁定对象的颗粒度很小,也是目前各大数据库管理软件所实现的锁定颗粒度最小的。

  4. 由于锁定颗粒度很小,所以发生锁定资源竞争的概率也小,能够给予应用程序尽可能大的并发处理能力提高一些需要高并发应用系统的整体性能。

  5. 虽然在并发处理能力上面有较大的优势,但是行级锁定也因此带来了不少弊端。

  6. 由于锁定资源的颗粒度很小,所以每次获取锁和释放锁需要做的事情也很多,带来的消耗自然也就更大了。

  7. 此外,行级锁定也最容易发生死锁。

表级锁定(table-level)

  1. 表级锁,直接锁定整张表,在你锁定期间,其他进程无法对该表进行写操作。如果你是写锁,则其他进程则读也不允许。

  2. 和行级锁定相反,表级别的锁定是mysql各存储引擎中最大颗粒度的锁定机制。

  3. 该锁定机制最大的特点就是实现逻辑非常简单,带来的系统负面影响最小。所以获取锁和释放锁的速度很快。

  4. 由于表级锁一次会将整个表锁定,所以可以很好的避免困扰我们的死锁问题。

  5. 当然,锁定颗粒度大带来的负面影响就是出现资源争用的概率也会很高,致使并发度大打折扣。

页级锁定(page-level)

  1. 页级锁定是MySQL中比较独特的一种锁定级别,在其他数据库管理软件中也并不是太常见。

  2. 页级锁定的特点是锁定颗粒度介于行级锁定和表级锁定之间,所以获取锁所需要的资源开销,以及所能提供的并发处理能力也同样介于上面二者之间。

  3. 另外,页级锁定和行级锁定一样,也会发生死锁。

小结

  1. 在数据库实现资源锁定的过程中,随着锁定资源颗粒度的减小,锁定相同数据量的数据所需要消耗的内存数量是越来越多,实现算法也会越来越复杂。

  2. 随着锁定资源颗粒度的减小,应用程序的访问请求遇到锁等待的可能性也会随之降低,系统整体并发度页随之提升。

  3. 在MySQL中,使用表级锁定的是MyISAM、MEmory、CSv等一些非事务型存储引擎,而使用行级锁的主要是InnoDB存储引擎和NDB Cluster存储引擎,页级锁定主要是BerkeleyDB存储引擎的锁定方式。

以上就是MySQL数据库锁定机制的介绍的详细内容,更多请关注微课江湖其它相关文章!

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 分享下mysql各个主要版本之间的差异
  • MySQL essential版本和普通版本有什么区别?
  • redhat 5.4下安装MYSQL全过程
  • 如何用SQL命令查看Mysql数据库大小
  • 解析mysql中如何获得数据库的大小
  • 解析mysql修改为utf8后仍然有乱码的问题
  • 5个常用的MySQL数据库管理工具详细介绍
  • 解析在MySQL里创建外键时ERROR 1005的解决办法
  • 解析远程连接管理其他机器上的MYSQL数据库
  • mysql 精简过程(删除一些文件)

相关文章

  • 2018-12-05Mysql学习笔记
  • 2018-12-05数据库的一些常用知识
  • 2017-05-11mysql 中存在null和空时创建唯一索引的方法
  • 2018-12-05Mysql分析-profile详解
  • 2018-12-05Oracle数据库下载及安装图文操作步骤
  • 2018-12-05关于mysql create routine权限的代码实例详解
  • 2017-05-11MySQL无GROUP BY直接HAVING返回空的问题分析
  • 2017-05-11mysql中使用UDF自动同步memcached效率笔记
  • 2018-12-05Access数据库的存储空间最大是多少
  • 2018-12-05深入理解MySQL进阶漂流记(四)

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • MySQL如何创建和删除索引?
    • 关于Mysql表,列,库增删改查的详细介绍
    • 减少mysql主从数据同步延迟问题的详解
    • 如何使用mysql语句创建联结
    • 影响MySQL性能的五大配置参数
    • SUSE Linux下源码编译方式安装MySQL 5.6过程分享
    • mysql中取系统当前时间,当前日期方便查询判定的代码
    • MySQL数据库中的安全设置方案
    • 数据库的用户帐号管理基础知识
    • 利用mysql的inet_aton()和inet_ntoa()函数存储IP地址的方法分享

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有