Mysql 引擎之 mylsam

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: MYSQL 浅谈MyISAM 存储引擎 思维导图   介绍 mysql中用的最多存储引擎就是innodb和myisam。做为Mysql的默认存储引擎,myisam值得我们学习一下,以下是我对《高性能MYSQL》书中提到的myisam的理解,请大家多多指教。


MYSQL 浅谈MyISAM 存储引擎

 思维导图

 

 

 介绍

 

mysql中用的最多存储引擎就是innodb和myisam。做为Mysql的默认存储引擎,myisam值得我们学习一下,以下是我对《高性能MYSQL》书中提到的myisam的理解,请大家多多指教。

 

 特点

 

> 不支持事务

 

  证明如下:

     >> 表记录:t2表的engine是myisam。

 

    >> 操作

注意:如果你在数据库进行事务操作,但是事务无法成功,你就要看你的表引擎了,看这种引擎是否支持事务。

>> 下面请看innodb中的事务操作

  

> 存储结构:数据文件(.MYD),索引文件(.MYI)和结构文件(.frm)

   >> 特点:可以在不同服务器上拷贝数据文件和索引文件。

> 加锁和并发

         加锁:对整张表进行加锁,而不是行。

         并发:在读数据的时候,所有的表上都可以获得共享锁(读锁),每个连接都不互相干扰。

                 在写数据的时候,获得排他锁,会把整个表进行加锁,而其他的连接请求(读,写请求)都处于等待中。

> 修复表

   >> 查看表状态

    >> check一下表,看表是否正常。 

   >> repair(修复) 一下表。呵呵,我的这张表是正常的。

> 列索引。可以基于BLOB或TEXT类型列的前500个字符,创建相关索引。

   >> 给t2表添加一个text列。

   >> 表结构如下

   >> 为content字段添加全文索引

   >> 查看表的索引情况

> 延迟更新索引。MYISAM 默认把DELAY_KEY_WRITE开启, 整个选项是MYISAM引擎独有的。

注意:在查询结束后,不会将索引的改变数据写入磁盘,而是改变内存中的索引数据。只有在清理缓冲区或关闭表时才将索引块转储到磁盘。

> 压缩表

  >> 查看数据文件位置

  >> 压缩文件

 总结

 

 myisam在索引层和压缩层的卓越贡献,所以我们经常把myisam用于slave层,供客户端去读取。而myisam在写库操作的时候会产生排他锁,如果写操作一直占用的话,那么其他连接请求一直就处于等待中,从而造成堵塞,甚至能把服务器dang掉。

 


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
27 0
|
3月前
|
存储 关系型数据库 MySQL
十八、MySQL数据库引擎
十八、MySQL数据库引擎
43 0
|
4月前
|
存储 关系型数据库 MySQL
MySQL ⽀持哪些存储引擎?默认使⽤哪个?MyISAM 和 InnoDB 引擎有什么区别,如何选择?
MySQL ⽀持哪些存储引擎?默认使⽤哪个?MyISAM 和 InnoDB 引擎有什么区别,如何选择?
|
4月前
|
存储 关系型数据库 MySQL
Mysql数据库引擎
Mysql数据库引擎
43 0
|
4月前
|
存储 安全 关系型数据库
mysql账号管理建库以及常用引擎
mysql账号管理建库以及常用引擎
36 0
|
4月前
|
存储 关系型数据库 MySQL
RDS的引擎是innodb吗?
RDS的引擎是innodb吗?
49 1
|
4月前
|
关系型数据库 数据库 RDS
RDS的引擎是innodb吗?
RDS的引擎是innodb吗?
22 0
|
5月前
|
存储 安全 关系型数据库
MySQL储存引擎那些你不一定知道的东西
MySQL储存引擎那些你不一定知道的东西
28 0
MySQL储存引擎那些你不一定知道的东西
|
5月前
|
存储 关系型数据库 MySQL
Mysql数据库引擎
Mysql数据库引擎
36 0
|
6月前
|
存储 SQL 关系型数据库
使用MySQL之引擎,建库
使用MySQL之引擎,建库
31 0