热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

MyISAM引擎的表锁

MyISAM引擎特点简述不支持事务不支持外键较小的逐渐范围支持全文检索不支持GIB数据查询效率高使用表锁表锁特点锁住整个表,所以开销小,加锁比较快&#x

MyISAM引擎特点简述

  • 不支持事务
  • 不支持外键
  • 较小的逐渐范围
  • 支持全文检索
  • 不支持GIB数据
  • 查询效率高
  • 使用表锁

表锁特点

  锁住整个表,所以开销小,加锁比较快,无死锁情况,锁的粒度较大,在并发情况下,产生锁等待的概率比较高,所以支持的并发数较低,一般用于查找。

表锁类型

手动表锁语法

mysql> LOCK TABLE 表名 [READ | WRITE] [,表名 [READ | WRITE]...] #加锁
mysql
> UNLOCK TABLES #解锁

状态查询

mysql> SHOW STATUS LIKE 'Table_locks_immediate';

表示可以立即获取锁的查询次数,每获取一次锁就增加1

 

mysql> SHOW STATUS LIKE 'Table_locks_waited';

表示锁等待的次数

 

最佳实践

读锁(共享锁)

步骤Session1Session2
1给myisam_lock加读锁 
2可以查询myisam_lock表数据可以查询myisam_lock表数据
3不可以增删改myisam_lock表数据增删改myisam_lock表数据阻塞
4不可以增删改查其他表数据可以增删改查其他表数据
5释放myisam_lock的读锁释放读锁同时阻塞的增删改成功

 

 

 

 

 

 

写锁(排它锁)

步骤Session1Session2
1给myisam_lock加写锁 
2可以查询myisam_lock表数据查询myisam_lock表数据阻塞
3释放myisam_lock的写锁释放写锁同时阻塞的查询成功
4给myisam_lock加写锁 
5可以增删改myisam_lock表数据增删改myisam_lock表数据阻塞
6不可以增删改查其他表数据可以增删改查其他表数据
7释放myisam_lock的写锁释放写锁同时阻塞的增删改成功

 

 

 

 

 

 

 

 

实践结束,我觉得有必要解释一下关于表锁的特点:

  • 表锁开销小,因为直接锁住整个表,不用太多查找,索引消耗的性能也比较小。
  • 加锁快,因为好找所以加锁时间也短。
  • 无死锁情况,因为MyISAM没有事务,所以就谈不上死锁。
  • 表锁粒度大,因为锁住所有表数据,这还不大吗?
  • 锁等待概率大,每次更新一下就要锁住表,所有增删改都需要排队。
  • 并发数较低,增删改都是排它锁,其他线程连访问都会阻塞,并发肯定低。
  • 一般用于查,因为查是共享锁,不影响其他线程读取,所以查的性能很好。

 

本文索引关键字:

读锁(共享锁):http://www.cnblogs.com/huanStephen/p/8067972.html#s_lock

写锁(排它锁):http://www.cnblogs.com/huanStephen/p/8067972.html#x_lock

欢迎大家索引!

转:https://www.cnblogs.com/huanStephen/p/8067972.html



推荐阅读
  • 本文介绍了 Go 语言中的高性能、可扩展、轻量级 Web 框架 Echo。Echo 框架简单易用,仅需几行代码即可启动一个高性能 HTTP 服务。 ... [详细]
  • centos 7.0 lnmp成功安装过程(很乱)
    下载nginx[rootlocalhostsrc]#wgethttp:nginx.orgdownloadnginx-1.7.9.tar.gz--2015-01-2412:55:2 ... [详细]
  • Cookie学习小结
    Cookie学习小结 ... [详细]
  • 本文将深入探讨 iOS 中的 Grand Central Dispatch (GCD),并介绍如何利用 GCD 进行高效多线程编程。如果你对线程的基本概念还不熟悉,建议先阅读相关基础资料。 ... [详细]
  • 为什么多数程序员难以成为架构师?
    探讨80%的程序员为何难以晋升为架构师,涉及技术深度、经验积累和综合能力等方面。本文将详细解析Tomcat的配置和服务组件,帮助读者理解其内部机制。 ... [详细]
  • 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
    HTTP协议是不加密传输数据的,也就是用户跟你的网站之间传递数据有可能在途中被截获,破解传递的真实内容,所以使用不加密的HTTP的网站是不 ... [详细]
  • ABP框架是ASP.NET Boilerplate的简称,它不仅是一个开源且文档丰富的应用程序框架,还提供了一套基于领域驱动设计(DDD)的最佳实践架构模型。本文将详细介绍ABP框架的特点、项目结构及其在Web API优先架构中的应用。 ... [详细]
  • 【转】强大的矩阵奇异值分解(SVD)及其应用
    在工程实践中,经常要对大矩阵进行计算,除了使用分布式处理方法以外,就是通过理论方法,对矩阵降维。一下文章,我在 ... [详细]
  • 深入理解Java多线程与并发机制
    本文探讨了Java多线程和并发机制的核心概念,包括多线程类的分类、执行器框架、并发容器及控制工具。通过详细解析这些组件,帮助开发者更好地理解和应用多线程技术。 ... [详细]
  • 本文为初学者提供了一条清晰的学习路线,帮助他们逐步成长为优秀的Web开发人员。通过十个关键步骤,涵盖从基础到高级的各个方面,确保每位学习者都能找到适合自己的学习方向。 ... [详细]
  • 从零开始编译Linux系统:第16章 全新起点
    本章将详细介绍如何从零开始编译一套完整的Linux系统,涵盖关键组件如glibc库的介绍及其重要性。通过本文,读者将了解从源代码构建Linux系统的全过程。 ... [详细]
  • 本文详细介绍如何在忘记MySQL服务器密码的情况下进行密码重置,包括具体的步骤和注意事项。 ... [详细]
  • 周排行与月排行榜开发总结
    本文详细介绍了如何在PHP中实现周排行和月排行榜的开发,包括数据库设计、数据记录和查询方法。涉及的知识点包括MySQL的GROUP BY、WEEK和MONTH函数。 ... [详细]
  • PHP 5.5.31 和 PHP 5.6.17 安全更新发布
    PHP 5.5.31 和 PHP 5.6.17 已正式发布,主要包含多个安全修复。强烈建议所有用户尽快升级至最新版本以确保系统安全。 ... [详细]
  • 本文介绍了多种开源数据库及其核心数据结构和算法,包括MySQL的B+树、MVCC和WAL,MongoDB的tokuDB和cola,boltDB的追加仅树和mmap,levelDB的LSM树,以及内存缓存中的一致性哈希。 ... [详细]
author-avatar
我要知道521无敌
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有