MySQL浅谈MyISAM存储引擎

数据库 MySQL
mysql中用的最多存储引擎就是innodb和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掉。

参考文件:《高性能MYSQL》

原文连接:http://www.cnblogs.com/baochuan/archive/2012/03/15/2398276.html

【编辑推荐】

  1. SQL数据库之数据类型BOOL/BOOLEAN与TINYINT测试总结
  2. MySQL服务端编码设置
  3. MySQL源码学习:MDL字典锁
  4. MySQL Cluster开发环境简明部署
  5. MySQL的四种不同查询的分析

 

责任编辑:林师授 来源: 川山甲的博客
相关推荐

2009-05-05 10:19:37

存储引擎InnoDBMyISAM

2019-06-11 16:11:16

MySQLMyISAMInnoDB

2010-05-21 16:10:28

2018-06-14 10:44:59

MySQLMyISAMInnoDB

2009-05-19 09:58:41

MyISAMInnoDB存储引擎

2011-05-03 10:09:37

MySQL存储引擎

2010-05-21 15:53:30

2018-09-05 13:14:54

MySQLInnoDBMyISAM

2010-11-23 11:27:53

MySQL MyISA

2010-05-11 15:06:24

MySQL MyISA

2010-05-21 16:23:52

MySQL MyISA

2011-08-16 16:22:38

MySQL数据库存储引擎MyISAM

2018-08-31 10:53:25

MySQL存储引擎

2017-04-24 11:01:59

MySQL数据库架构设计

2019-01-14 14:25:25

MySQL存储逻辑架构

2021-08-10 14:29:06

MySQL数据库存储

2020-01-10 17:43:11

MySQL数据库文章

2019-12-12 10:38:10

mysql数据库nnodb

2010-06-13 13:50:02

MySQL存储引擎

2010-05-21 10:58:19

MySQL存储引擎
点赞
收藏

51CTO技术栈公众号