设为首页 收藏本站
查看: 880|回复: 0

[经验分享] MySQL存储引擎MyISAM和InnoDB

[复制链接]

尚未签到

发表于 2018-10-5 09:35:02 | 显示全部楼层 |阅读模式
MySQL存储引擎MyISAM和InnoDB

存储引擎


  • 在MySQL中的数据拥有各种不同的技术存储文件或内存中。这些技术中的每一种技术都使用不同的存储机制、索引技巧、锁定水平并且最终提供广泛的不用的功能和能力。通过选择不同的技术,能够获得额外的速度或者功能,从而改善应用的整体功能。这些不同的技术以及配套的相关功能在MySQL中被称之为存储引擎。
MyISAM存储引擎


  • MyISAM存储引擎是MySQL关系数据库系统5.5版本之前默认的存储引擎。
特点
  1、不支持事务
  2、表级锁定形式,数据在更新时锁定整个表
  3、数据库在读写过程中相互堵塞:


  • 1)、在数据写入的过程中阻塞用户读数据的读取
  • 2)、在数据读取的过程中阻塞用户写入数据
  4、可以通过key_buffer_size来设置缓存索引,提高访问的性能,减少磁盘IO的压力
  5、采用MyISAM存储引擎进行行数据单独写入或读取,速度较块且占用资源相对较少
  6、MyISAM存储引擎不支持外键约束,只支持全文索引
  7、每个MyISAM在磁盘上存储成三个文件,每一个的名字均以表的名字开始,扩展名指出文件类型:


  • 1)、.frm 文件存储表定义。
  • 2)、数据文件的扩展名为:.MYD(MYData)。
  • 3)、索引文件的扩展名为:.MYI(MYIndex)。
InnoDB存储引擎

特点
  1、支持事物
  2、行级锁定,但是全盘扫描仍然会是表级锁定。
  3、读写阻塞与事务隔离级别相关
  4、具有非常高效的缓存特性,能缓存索引,也能缓存数据
  5、表与主键以簇的方式存储
  6、支持分区、表空间,类似Oracle数据库
  7、支持外键约束,
  8、适合对硬件资源要求比较高的场合

配置合适的存储引擎

1、查看MySQL默认使用的存储引擎

  mysql -u root -p      #进入MySQL
  show engines;         #查看默认存储引擎

DSC0000.jpg


2、查看表存储引擎类型


  • 使用 show table status 命令查看:
  mysql -u root -p
  show table status from test where name='test';        #查看test数据库中的test表的存储引擎类型

DSC0001.jpg



  • 使用show create 查看表存储引擎类型:
  mysql -u root -p
  use test;      #使用test数据库
  show create table test;       #查看test表的存储引擎类型

DSC0002.jpg


3、修改存储引擎

    使用>
  mysql -u root -p
  use test;
  alter table test engine=MyISAM;       #修改test表的存储引擎类型
  show create table test;

DSC0003.jpg



  • 修改MySQL的配置文件my.cnf,可以指定defaut-storage-engine选项设置默认的存储引擎(只试用于新创建的表,已存在表的存储引擎类型不变):
  vim /etc/my.cnf       #编辑配置文件

  

#省略内容  
[mysqld]
  
default-storage-engines=MyISAM
  
#省略内容
  

  systemctl restart mysqld.service      #重启MySQL服务



  • 使用create table创建表时用engine指定存储引擎(现在数据库的默认存储引擎为MyISAM);
  mqsql -u root -p
  use test;
  create table test01(id int) engine=InnoDB;      #创建存储引擎为InnoDB的表
  show create table test01;

DSC0004.jpg



  • 使用mysql_convert_table_format命令可以批量转换存储引擎(只使用于MySQL5.5版本);
  yum install prel-DBI -y
  yum install prel-BDB-MySQL -y         #安装perl对MySQL的模块操作
  mysql_convert_table_format --user=root --password=密码 --socket=/temp/mysql.sock --engine=MyISAM test test
  但当使用此命令将存储引擎类型更改为InnoDB时,会出现报错,所以需要修改其命令的脚本文件
  vim /use/local/mysql/bin/mysql_convert_table_format

  

#省略内容  
"e|engine|type=s"   =>\$opt_engine, #将32行中的\$opt_type更改为\$opt_engine
  
#省略内容
  

  重新使用命令即可
  mysql_convert_table_format --user=root --password=密码 --socket=/temp/mysql.sock --engine=InnoDB test test




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-612514-1-1.html 上篇帖子: mysql聚合函数,运算操作 下篇帖子: MySQL存储引擎MyISAM和InnoDB
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表