热门标签 | 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



推荐阅读
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了如何使用ActionScript 3.0 (AS3) 连接并操作MySQL数据库。通过具体的代码示例和步骤说明,帮助开发者理解并实现这一过程。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • PHP 5.2.5 安装与配置指南
    本文详细介绍了 PHP 5.2.5 的安装和配置步骤,帮助开发者解决常见的环境配置问题,特别是上传图片时遇到的错误。通过本教程,您可以顺利搭建并优化 PHP 运行环境。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 本文深入探讨 MyBatis 中动态 SQL 的使用方法,包括 if/where、trim 自定义字符串截取规则、choose 分支选择、封装查询和修改条件的 where/set 标签、批量处理的 foreach 标签以及内置参数和 bind 的用法。 ... [详细]
  • HTTP 请求与响应详解
    本文深入探讨了HTTP请求和响应的结构,详细解释了每个部分的作用,并提供了相关示例。通过本文,读者可以全面理解HTTP协议中请求和响应的工作原理。 ... [详细]
  • Hadoop入门与核心组件详解
    本文详细介绍了Hadoop的基础知识及其核心组件,包括HDFS、MapReduce和YARN。通过本文,读者可以全面了解Hadoop的生态系统及应用场景。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
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社区 版权所有