教程集 www.jiaochengji.com
教程集 >  数据库  >  mysql  >  正文 有关MyISAM引擎的锁定机制

有关MyISAM引擎的锁定机制

发布时间:2016-02-26   编辑:jiaochengji.com
本文介绍下,mysql数据库中MyISAM引擎的锁定机制的相关知识,感兴趣的朋友可以参考下。

本节内容:
MyISAM引擎的锁定机制

在mysql数据库中,MyISAM存储引擎适合于读频率远大于写频率这一情况。
目前的应用可能会出现在某一时段读写频率相当。

大致如下:
一个客户端发出需要长时间运行的SELECT
其他客户端在同一个表上发出INSERT或者UPDATE,这个客户将等待SELECT完成
另一个客户在同一个表上发出另一个SELECT;因UPDATE或INSERT比SELECT有更高有优先级,该SELECT将等待UPDATE或INSERT完成,也将等待第一个SELECT完成
也就是说对MyISAM表的读操作,不会阻塞其他用户对同一表的读请求,但会阻塞对同一表的写请求;对 MyISAM表的写操作,则会阻塞其他用户对同一表的读和写操作
;MyISAM表的读操作与写操作之间,以及写操作之间是串行的!

解决方案:
MyISAM存储引擎有一个系统变量concurrent_insert,专门用以控制其并发插入的行为,其值分别可以为0、1或2。
0 不允许并发操作
1 如果MyISAM表中没有空洞(即表的中间没有被删除的行),MyISAM允许在一个进程读表的同时,另一个进程从表尾插入记录。这也是MySQL的默认设置。
2 无论MyISAM表中有没有空洞,都允许在表尾并发插入记录
使用--low-priority-updates启用mysqld。这将给所有更新(修改)一个表的语句以比SELECT语句低的优先级。在这种情况下,在先前情形的最后的SELECT语句将在INSERT语句
前执行。

为max_write_lock_count设置一个低值,使得在一定数量的WRITE锁定后,给出READ锁定
使用LOW_PRIORITY属性给于一个特定的INSERT,UPDATE或DELETE较低的优先级
使用HIGH_PRIORITY属性给于一个特定的SELECT
使用INSERT DELAYED语句

您可能感兴趣的文章:
有关MyISAM引擎的锁定机制
修改mysql默认存储引擎的方法
MySQL正确的myisam转innodb的方法
mysql LOCK TABLES和UNLOCK TABLES
mysql如何锁定单个表
mysql数据库修改数据表引擎方法
mysql数据库引擎MyISAM与InnoDB的区别详解
mysql innodb数据库批量转换表引擎为MyISAM的方法
MySQL数据库之锁的详解
高性能mysql(第二版)学习笔记之架构优化和索引

关键词: MyISAM  数据表引擎   
[关闭]
~ ~