`

mysql的锁表问题

阅读更多

mysql的锁表问题 SHOW PROCESSLIST查看数据库中表的状态,是否被锁; kill id //杀掉被锁的表 =================================================== set autocommit=0; select * from t1 where uid=’xxxx’ for update //在有索引(例如uid)的情况下是行锁,否则是表锁 insert into t1 values(1,’xxxxx’); commit; ===================================================== lock tables t1 write|read; insert into t1 values(2,’xxxxx’); //只有insert unlock tables; 2 《轻松掌握MySQL数据库锁机制的相关原理》 MySQL 5.1支持对MyISAM和MEMORY表进行表级锁定,对BDB表进行页级锁定,对InnoDB 表进行行级锁定。在许多情况下,可以根据培训猜测应用程序使用哪类锁定类型最好,但一般很难说出某个给出的锁类型就比另一个好。一切取决于应用程序,应用程序的不同部分可能需要不同的锁类型。为了确定是否想要使用行级锁定的存储引擎,应看看应用程序做什么并且混合使用什么样的选择和更新语句。例如,大多数Web应用程序执行许多选择,而很少进行删除,只对关键字的值进行更新,并且只插入少量具体的表。基本MySQL MyISAM设置已经调节得很好。 在MySQL中对于使用表级锁定的存储引擎,表锁定时不会死锁的。这通过总是在一个查询开始时立即请求所有必要的锁定并且总是以同样的顺序锁定表来管理。 对WRITE,MySQL使用的表锁定方法原理如下: ◆ 如果在表上没有锁,在它上面放一个写锁。 ◆否则,把锁定请求放在写锁定队列中。 对READ,MySQL使用的锁定方法原理如下: ◆如果在表上没有写锁定,把一个读锁定放在它上面。 ◆否则,把锁请求放在读锁定队列中。 当一个锁定被释放时,锁定可被写锁定队列中的线程得到,然后是读锁定队列中的线程。 这意味着,如果你在一个表上有许多更新,SELECT语句将等待直到没有更多的更新。 如果INSERT 语句不冲突,可以自由为MyISAM 表混合并行的INSERT 和SELECT 语句而不需要锁定。 InnoDB 使用行锁定,BDB 使用页锁定。对于这两种存储引擎,都可能存在死锁。这是因为,在SQL语句处理期间,InnoDB 自动获得行锁定,BDB 获得页锁定,而不是在事务启动时获得。 行级锁定的优点: · 当在许多线程中访问不同的行时只存在少量锁定冲突。 · 回滚时只有少量的更改。 · 可以长时间锁定单一的行。 行级锁定的缺点: · 比页级或表级锁定占用更多的内存。 · 当在表的大部分中使用时,比页级或表级锁定速度慢,因为你必须获取更多的锁。 · 如果你在大部分数据上经常进行 GROUP BY 操作或者必须经常扫描整个表,比其它锁定明显慢很多。 · 用高级别锁定,通过支持不同的类型锁定,你也可以很容易地调节应用程序,因为其锁成本小于行级锁定。 在以下情况下,表锁定优先于页级或行级锁定: · 表的大部分语句用于读取。 · 对严格的关键字进行读取和更新,你可以更新或删除可以用单一的读取的关键字来提取的一行: • UPDATE tbl_name SET column = value WHERE unique_key_col = key_value ; • DELETE FROM tbl_name WHERE unique_key_col = key_value ; · SELECT 结合并行的INSERT 语句,并且只有很少的UPDATE或 DELETE 语句。 · 在整个表上有许多扫描或 GROUP BY 操作,没有任何写操作。 不同于行级或页级锁定的选项: · 版本(例如,为并行的插入在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 完成。 下面描述了一些方法来避免或减少表锁定造成的竞争: · 试图使 SELECT 语句运行得更快。可能必须创建一些摘要(summary)表做到这点。 · 用–low-priority-updates启动mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的第2个SELECT语句将在UPDATE语句前执行,而不需要等候第1个 SELECT 完成。 · 可以使用SET_UPDATES=1语句指定具体连接中的所有更新应使用低优先级。 · 可以用LOW_PRIORITY属性给与一个特定的INSERT、UPDATE或DELETE语句较低优先级。 · 可以用HIGH_PRIORITY属性给与一个特定的SELECT语句较高优先级。 · 为max_write_lock_count系统变量指定一个低值来启动mysqld来强制MySQL在具体数量的插入完成后临时提高所有等待一个表的SELECT 语句的优先级。这样允许在一定数量的WRITE锁定后给出READ锁定。 · 如果你有关于INSERT结合SELECT的问题,切换到使用新的MyISAM表,因为它们支持并发的SELECT和INSERT。 · 如果你对同一个表混合插入和删除,INSERT DELAYED将会有很大的帮助。 · 如果你对同一个表混合使用 SELECT 和DELETE 语句出现问题,DELETE 的LIMIT 选项可以有所帮助。 · 对 SELECT 语句使用SQL_BUFFER_RESULT可以帮助使表锁定时间变短。 · 可以更改mysys/thr_lock.c中的锁代码以使用单一的队列。在这种情况下,写锁定和读锁定将具有相同的优先级,对一些应用程序会有帮助。 这里是一些MySQL中表锁定相关的技巧: · 如果不混合更新与需要在同一个表中检查许多行的选择,可以进行并行操作。 · 可以使用 LOCK TABLES 来提高速度,因为在一个锁定中进行许多更新比没有锁定的更新要快得多。将表中的内容切分为几个表也可以有所帮助。 · 如果在MySQL中表锁定时遇到速度问题,可以将表转换为 InnoDB 或BDB 表来提高性能

分享到:
评论

相关推荐

    MYSQL锁表问题的解决方法

    本文将介绍几种解决MySQL锁表问题的方法。 1. **查看并杀死锁定进程** 使用`SHOW PROCESSLIST`命令可以查看当前所有正在执行的SQL语句及其状态,包括是否被锁定。如果发现有锁定的进程,可以使用`KILL`命令来终止...

    MySQL锁类型以及子查询锁表问题、解锁1

    锁表操作如`LOCK TABLES tbl_name READ/WRITE;`可以在备份或维护时使用,它会阻止其他用户对指定表进行读写操作,直到执行`UNLOCK TABLES;`为止。 总的来说,理解和正确使用MySQL的锁机制对于优化并发性能和避免...

    MYSQL 解锁与锁表介绍

    MySQL锁概述   相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁...

    mysql锁表解表

    MySQL在进行alter table等DDL操作时,有时会出现Waiting for table metadata lock的等待场景。而且,一旦alter table TableA的操作停滞在...如果是产品环境的核心表出现了这样的锁等待队列,就会造成灾难性的后果。

    MYSQL锁机制全揭秘

    在解决MySQL锁问题时,需要注意选择合适的事务隔离级别,因为不同级别的隔离,锁的使用情况也不同。此外,合理设计数据库表结构、索引、查询语句等,都有助于减少锁争用,提高性能。 页面锁是BDB存储引擎所采用的一...

    mysql锁表1

    在MySQL数据库管理系统中,"锁表"是一种重要的并发控制机制,用于确保在多用户环境中数据的一致性和完整性。锁能够防止多个用户同时修改同一数据,从而避免数据冲突和不一致。本篇文章将深入探讨MySQL中的锁表机制...

    mysql 锁机制及mysql中的锁介绍.pdf

    系统介绍mysql锁机制

    MySQL不停机不锁表主从同步与读写分离配置

    ### MySQL不停机不锁表主从同步与读写分离配置详解 #### 一、XtraBackup 安装 为了实现MySQL不停机不锁表的主从同步与读写分离配置,首先需要安装XtraBackup工具。XtraBackup是一款非常优秀的开源备份工具,尤其...

    值得学习的MySQL行级锁、表级锁、页级锁详细介绍

    值得学习的MySQL行级锁、表级锁、页级锁详细介绍

    MYSQL锁机制

    ### MySQL锁机制详解 #### 一、MySQL锁机制概述 MySQL中的锁机制是数据库管理系统用于控制并发事务对数据资源访问的关键技术之一。合理地管理和利用锁机制能够有效地防止数据不一致性和提高系统的并发处理能力。...

    MySQL的锁机制解析

    MySQL中的锁大致可以分为两大类:行级锁(Row-Level Locks)和表级锁(Table-Level Locks)。行级锁在粒度上更细,允许更多的并发操作,但开销也相对较大。表级锁则相反,它锁定整个表,提供较低的并发性,但开销较...

    MySQL锁详解

    首先,MySQL的锁机制主要有表级锁、行级锁以及页面锁三种。不同的存储引擎对锁的支持也不同。MyISAM和MEMORY存储引擎使用表级锁,BDB存储引擎支持页面锁,同时也可以使用表级锁,而InnoDB存储引擎则同时支持行级锁和...

    MySQL8.0锁机制和事务

    MySQL 8.0 锁机制和事务 MySQL 8.0 中的锁机制和事务是数据库系统中非常重要的概念。锁机制是指数据库系统中对数据访问的控制机制,而事务是指数据库系统中的一组操作单元。了解锁机制和事务是非常关键的,因为它们...

    mysql锁表和解锁语句分享

    MySQL锁表和解锁语句分享 MySQL 中有三种锁的级别:页级、表级、行级。每种锁级别都有其典型的引擎,页级的典型代表引擎为 BDB,表级的典型代表引擎为 MyISAM、MEMORY 以及很久以前的 ISAM,行级的典型代表引擎为 ...

    MySQL:锁机制.pdf

    本知识点详细解读了MySQL锁机制的定义、分类、特点以及具体的应用案例。 1. 锁的定义和分类 在数据库系统中,锁是用来控制多个用户或进程对同一数据资源进行访问的同步机制。它解决的是多个操作同时对同一资源进行...

    MySQL高级 锁机制

    此外,还存在一种特殊类型的行锁——间隙锁(Gap Lock),它不仅锁定特定的行,还锁定行之间的间隙,防止其他用户插入数据,从而避免幻读问题。然而,间隙锁可能导致不必要的阻塞。例如,如果一个事务在某范围内锁定...

Global site tag (gtag.js) - Google Analytics