MySQL改变表的存储引擎方法
改变MySQL表的存储引擎方法
1、最简单的方法是使用alter table语句,例如
alter table tablename ENGINE = InnoDB;
上述方法可以适用于任何存储引擎的转换,但有一个问题,需要执行很长时间,MySQL会按行将数据从原表复制到一张新的表中,在复制期间可能会消耗系统的所有I/O能力,同时原表上会加上锁,所以,在繁忙的表上执行操作要特别小心。
另外,如果转换表的存储引擎,将会失去和原引擎相关的所有特性,例如,将一张InnoDB表转换为MyISAM,然后再转换回InnoDB,原InnoDB表上的所有的外健将丢失。
2、导入导出
为了更好的控制转换的过程,可以使用mysqldump工具将数据导出到文件,然后修改文件中create table语句的存储引擎选项,注意同时修改表名,因为同一个数据库中不能存在相同的表名,即使它们使用的是不同的存储引擎。同时要注意mysqldump会默认自动的在create table 语句前加上drop table语句,不注意这一点可能会导致数据丢失。
mysqldump的使用方法
3、创建与查询(create 和 select)
第三种技术综合实现了第一种的高效和第二种的安全,不需要导出整张表的数据,而是先创建一个新的存储引擎的表,然后利用insert 和select 语法来导入数据
1、create table innodb_table like myisam_table;
2、alter table innodb_table engine = InnoDB;
3、insert into innodb_table select * from myisam_table;
文章摘录自《高性能MySQL第三版》
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhggfihe
系列文章
更多
同类精品
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01 -
怎样阻止微信小程序自动打开
PHP中文网 06-13