源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

MYSQL 浅谈MyISAM 存储引擎

  • 时间:2021-05-11 08:33 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:MYSQL 浅谈MyISAM 存储引擎
思维导图
 
[img]http://files.jb51.net/file_images/article/201204/201204140247222.png[/img]
 
 介绍
 
       mysql中用的最多存储引擎就是innodb和myisam。做为Mysql的默认存储引擎,myisam值得我们学习一下,以下是我对《高性能MYSQL》书中提到的myisam的理解,请大家多多指教。
 
 特点
 
> 不支持事务
 
  证明如下:
     >> 表记录:t2表的engine是myisam。
[img]http://files.jb51.net/file_images/article/201204/201204140247223.png[/img]       >> 操作 [img]http://files.jb51.net/file_images/article/201204/201204140247224.png[/img]
注意:如果你在数据库进行事务操作,但是事务无法成功,你就要看你的表引擎了,看这种引擎是否支持事务。
>> 下面请看innodb中的事务操作
[img]http://files.jb51.net/file_images/article/201204/201204140247225.png[/img]
  
> 存储结构:数据文件(.MYD),索引文件(.MYI)和结构文件(.frm)
   >> 特点:可以在不同服务器上拷贝数据文件和索引文件。
[img]http://files.jb51.net/file_images/article/201204/201204140247226.png[/img]
> 加锁和并发
         加锁:对整张表进行加锁,而不是行。
         并发:在读数据的时候,所有的表上都可以获得共享锁(读锁),每个连接都不互相干扰。
                 在写数据的时候,获得排他锁,会把整个表进行加锁,而其他的连接请求(读,写请求)都处于等待中。
> 修复表
   >> 查看表状态
[img]http://files.jb51.net/file_images/article/201204/201204140247227.png[/img]
    >> check一下表,看表是否正常。 
[img]http://files.jb51.net/file_images/article/201204/201204140247228.png[/img]
   >> repair(修复) 一下表。呵呵,我的这张表是正常的。
[img]http://files.jb51.net/file_images/article/201204/201204140247229.png[/img]
> 列索引。可以基于BLOB或TEXT类型列的前500个字符,创建相关索引。
   >> 给t2表添加一个text列。
[img]http://files.jb51.net/file_images/article/201204/2012041402472210.png[/img]
   >> 表结构如下
[img]http://files.jb51.net/file_images/article/201204/2012041402472211.png[/img]    >> 为content字段添加全文索引 [img]http://files.jb51.net/file_images/article/201204/2012041402472212.png[/img]    >> 查看表的索引情况 [img]http://files.jb51.net/file_images/article/201204/2012041402472213.png[/img]
> 延迟更新索引。MYISAM 默认把DELAY_KEY_WRITE开启, 整个选项是MYISAM引擎独有的。
[img]http://files.jb51.net/file_images/article/201204/2012041402472214.png[/img] 注意:在查询结束后,不会将索引的改变数据写入磁盘,而是改变内存中的索引数据。只有在清理缓冲区或关闭表时才将索引块转储到磁盘。
> 压缩表
  >> 查看数据文件位置 [img]http://files.jb51.net/file_images/article/201204/2012041402472215.png[/img]   >> 压缩文件 [img]http://files.jb51.net/file_images/article/201204/2012041402472216.png[/img]
 总结
 
 myisam在索引层和压缩层的卓越贡献,所以我们经常把myisam用于slave层,供客户端去读取。而myisam在写库操作的时候会产生排他锁,如果写操作一直占用的话,那么其他连接请求一直就处于等待中,从而造成堵塞,甚至能把服务器dang掉。
 
参考文件:《高性能MYSQL》
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部