前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MYSQL 浅谈MyISAM 存储引擎

MYSQL 浅谈MyISAM 存储引擎

作者头像
Java架构师历程
发布2018-09-26 17:02:03
1.9K0
发布2018-09-26 17:02:03
举报
文章被收录于专栏:Java架构师历程Java架构师历程

 思维导图

 介绍

       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》

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017年4月25日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档