我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MyISAM的OPTIMIZE有什么作用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MyISAM的OPTIMIZE有什么作用

这篇文章主要介绍“MyISAM的OPTIMIZE有什么作用”,在日常操作中,相信很多人在MyISAM的OPTIMIZE有什么作用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MyISAM的OPTIMIZE有什么作用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

一些介绍
   通过OPTIMIZE 命令来整理MyISAM 表的文件。这就像我们使用Windows 操作系统会每过一段时间
后都会做一次磁盘碎片整理,让系统中的文件尽量使用连续空间,提高文件的访问速度。MyISAM 在
通过OPTIMIZE 优化整理的时候,主要也是将因为数据删除和更新造成的碎片空间清理,使整个文件
连续在一起。一般来说,在每次做了较大的数据删除操作之后都需要做一次OPTIMIZE 操作。而且每
个季度都应该有一次OPTIMIZE 的维护操作。

一、创建一张表,并插入大量数据
(localhost@testdb)[root]> select * from test5;
+----+------+
| id | name |
+----+------+
|  1 | aa   |

(localhost@testdb)[root]> insert into test5 select * from test5;
Query OK, 12288 rows affected (0.07 sec)
(localhost@testdb)[root]> 
(localhost@testdb)[root]> 

(localhost@testdb)[root]> show index from test5;
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| test5 |          1 | id       |            1 | id          | A         |        NULL |     NULL | NULL   |      | BTREE      |         |               |
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
1 row in set (0.00 sec)


(localhost@testdb)[root]> 
(localhost@testdb)[root]> 
(localhost@testdb)[root]> 

[root@node1 testdb]# ls -trl
total 2096
-rw-r----- 1 mysql mysql     65 Feb 23 09:54 db.opt
-rw-r----- 1 mysql mysql   8586 Feb 26 16:18 test5.frm
-rw-r----- 1 mysql mysql 293888 Feb 29 15:52 test5.MYI
-rw-r----- 1 mysql mysql 491520 Feb 29 15:52 test5.MYD
二、删除表部分数据
(localhost@testdb)[root]> delete from test5 where id=1;
Query OK, 8192 rows affected (0.16 sec)
(localhost@testdb)[root]> 
(localhost@testdb)[root]> 
(localhost@testdb)[root]> 
(localhost@testdb)[root]> 
(localhost@testdb)[root]> commit;
Query OK, 0 rows affected (0.00 sec)
(localhost@testdb)[root]> delete from test5 where id=2;
Query OK, 8192 rows affected (0.14 sec)
(localhost@testdb)[root]> commit;
Query OK, 0 rows affected (0.00 sec)

三、做optimize操作
(localhost@testdb)[root]> optimize table test5;
+--------------+----------+----------+----------+
| Table        | Op       | Msg_type | Msg_text |
+--------------+----------+----------+----------+
| testdb.test5 | optimize | status   | OK       |
+--------------+----------+----------+----------+
1 row in set (0.02 sec)

(localhost@testdb)[root]> show index from test5;
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| test5 |          1 | id       |            1 | id          | A         |           1 |     NULL | NULL   |      | BTREE      |         |               |
+-------+------------+----------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
1 row in set (0.00 sec)

四、操作完成之后,索引和数据都减小
[root@node1 testdb]# ls -trl
total 1576
-rw-r----- 1 mysql mysql     65 Feb 23 09:54 db.opt
-rw-r----- 1 mysql mysql   8586 Feb 26 16:18 test5.frm
-rw-r----- 1 mysql mysql  87040 Feb 29 15:53 test5.MYI
-rw-r----- 1 mysql mysql 163840 Feb 29 15:53 test5.MYD

到此,关于“MyISAM的OPTIMIZE有什么作用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MyISAM的OPTIMIZE有什么作用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

mysql中optimize的作用是什么

在MySQL中,OPTIMIZE命令用于优化数据库表结构,以提高查询性能和减少存储空间的占用。当表中有大量的删除和更新操作时,表中会留下很多空洞和碎片,影响查询性能和存储效率。使用OPTIMIZE命令可以重新组织表的存储结构,将数据重新排列
mysql中optimize的作用是什么
2024-04-09

mysql中myisam的作用是什么

MyISAM 是 MySQL 中的一种存储引擎,它的作用是用于管理数据库表的存储和检索。使用 MyISAM 存储引擎的表在磁盘上以单独文件形式保存,支持表级锁定和全文索引等功能。MyISAM 存储引擎适用于读取频繁的应用场景,但不适合并发写
mysql中myisam的作用是什么
2024-03-15

mysql中optimize的用法是什么

在MySQL中,OPTIMIZE TABLE命令用于对表进行优化。该命令可以帮助数据库系统进行资源的重新整理,包括对表中碎片化空间的回收和重新排列数据,以提高查询和操作性能。语法:OPTIMIZE TABLE table_name;示例
mysql中optimize的用法是什么
2024-04-09

mysql中myisam的用法是什么

MyISAM是MySQL数据库中一种常见的存储引擎,它提供了对表级锁定的支持,适合于读取频繁、写入不频繁的应用场景。使用MyISAM存储引擎,可以实现以下操作:创建表:在创建表时,可以指定使用MyISAM存储引擎,例如:CREATE TAB
mysql中myisam的用法是什么
2024-03-15

mysql中myisam与innodb的区别是什么

MyISAM和InnoDB是MySQL数据库中两种最常用的存储引擎,它们之间有一些重要的区别:ACID属性:InnoDB支持事务,具有ACID(原子性、一致性、隔离性、持久性)属性,可以确保数据的完整性和一致性。而MyISAM不支持事务。锁
mysql中myisam与innodb的区别是什么
2024-03-15

编程热搜

目录