MySQL数据库锁机制的相关原理简介

来源:asp之家 时间:2010-04-22 15:34:00 

不同于行级或页级锁定的选项:

· 版本(例如,为并行的插入在MySQL中使用的技术),其中可以一个写操作,同时有许多读取操作。这明数据库或表支持数据依赖的不同视图,取决于访问何时开始。其它共同的术语是“时间跟踪”、“写复制”或者“按需复制”。

· 按需复制在许多情况下优先于页级或行级锁定。然而,在最坏的情况下,它可能比使用常规锁定使用多的内存。

· 除了行级锁定外,你可以使用应用程序级锁定,例如在MySQL中使用GET_LOCK()和RELEASE_LOCK()。这些是建议性锁定,它们只能在运行良好的应用程序中工作。

为达到最高锁定速度,除InnoDB 和BDB 之外,对所有存储引擎,MySQL使用表锁定(而不是页、行或者列锁定)。对于InnoDB 和BDB 表,如果你用LOCK TABLES显式锁定表,MySQL只使用表锁定;如果你不使用LOCK TABLES,因为 InnoDB 使用自动行级锁定而BDB 使用页级锁定来保证事务隔离。

但是对于大表,对于大多数应用程序,表锁定比行锁定更好,但存在部分缺陷。表锁定使许多线程同时从一个表中进行读取操作,但如果一个线程想要对表进行写操作,它必须首先获得独占访问。更新期间,所有其它想要访问该表的线程必须等待直到更新完成。

表更新通常情况认为比表检索更重要,因此给予它们更高的优先级。这应确保更新一个表的活动不能“饿死”,即使该表上有很繁重的SELECT 活动。

表锁定在这种情况下会造成问题,例如当线程正等待,因为硬盘已满并且在线程可以处理之前必须有空闲空间。在这种情况下,所有想要访问出现问题的表的线程也被设置成等待状态,直到有更多的硬盘空间可用。

表锁定在下面的情况下也存在问题:

· 一个客户发出长时间运行的查询。

· 然后,另一个客户对同一个表进行更新。该客户必须等待直到SELECT完成。

· 另一个客户对同一个表上发出了另一个 SELECT 语句。因为UPDATE比 SELECT 优先级高,该SELECT 语句等待UPDATE完成,并且等待第1个 SELECT 完成。



标签:MySQL,数据库锁,MySQL锁死
0
投稿

猜你喜欢

  • Node.js原理阻塞和EventEmitter及其继承的运用实战

    2024-05-05 09:21:33
  • Java开发之Spring连接数据库方法实例分析

    2024-01-26 02:00:54
  • 使用11行Python代码盗取了室友的U盘内容

    2021-04-05 04:08:21
  • SQL Server 服务器优化技巧浅谈

    2024-01-13 17:31:01
  • Mysql5.7忘记root密码及mysql5.7修改root密码的方法

    2024-01-24 16:04:29
  • 聊聊Javascript中try catch的2个作用

    2024-04-22 13:25:57
  • python 爬取腾讯视频评论的实现步骤

    2021-06-19 03:57:58
  • 用SQL统计SQLServe表存储空间大小的代码

    2012-06-06 19:52:22
  • 利用Python进行数据可视化的实例代码

    2023-11-24 10:21:45
  • Spark在Windows下的环境搭建方法

    2023-07-16 11:35:45
  • Python实现视频中添加音频工具详解

    2022-06-03 12:32:28
  • python使用pika库调用rabbitmq交换机模式详解

    2024-01-01 06:28:18
  • opencv中颜色空间转换函数cv2.cvtColor()使用

    2023-03-10 18:22:38
  • Python的ORM框架中SQLAlchemy库的查询操作的教程

    2023-11-20 19:33:01
  • 推荐一篇不错的新手asp编程的基本法则

    2011-04-15 11:08:00
  • sql server 复制表从一个数据库到另一个数据库

    2024-01-18 23:51:55
  • 用python给csv里的数据排序的具体代码

    2021-02-15 01:12:25
  • 深入解析Go语言编程中slice切片结构

    2024-04-25 15:01:23
  • python正则实现计算器功能

    2022-06-13 06:14:00
  • SQL SERVER数据库开发之触发器的应用

    2008-06-23 13:09:00
  • asp之家 网络编程 m.aspxhome.com