mysql myisam存储引擎_MYSQL 浅谈MyISAM 存储引擎

本文介绍了MySQL的MyISAM存储引擎,包括其不支持事务的特点,存储结构(.MYD, .MYI, .FRM文件),加锁与并发处理(全表锁定),修复表的方法,列索引(支持BLOB或TEXT列的前500个字符索引),延迟更新索引以及压缩表功能。MyISAM适用于读取密集型场景,但在写操作时可能导致锁竞争和性能问题。
摘要由CSDN通过智能技术生成

思维导图

05bfce657287015f4a3552d677f64f81.png

介绍

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

特点

> 不支持事务

证明如下:

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

f8a8d63e75ebcd52087dd4524db8c5ab.png

>> 操作

2febdf7ec41137180d2c73543ea1e52b.png

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

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

b5800c1a02c673a461c7f11928916881.png

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

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

8764a9d7599ece792ef39b2c2487c926.png

> 加锁和并发

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

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

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

> 修复表

>> 查看表状态

37f20f5d94773e48e4627d194d8c4155.png

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

01af5fe0b2dcba65388ea501219ca3ac.png

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

7c1eabd7366841cf6dfb3a51376fa9a8.png

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

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

88176bb82d499b57b48a4aa88199a3dd.png

>> 表结构如下

6c4b9654a03459e3e91f06e3442465a5.png

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

ea25be22ccb4802f653ab4e25ecfaa7f.png

>> 查看表的索引情况

924de9477e9fcfba9b41786a933f6433.png

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

17eb75dc6aaf85978ead2930656ad61e.png

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

> 压缩表

>> 查看数据文件位置

a4e2cb265b994a33b58561a251d33c3c.png

>> 压缩文件

725859091afa93bb3e8a6eb0e5251ccf.png

总结

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

参考文件:《高性能MYSQL》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值