目录
1. myisampack压缩表
2. myisampack备份数据库文件
3. 向T5中插入数据
首页 数据库 mysql教程 每天进步一点达MySQLmyisampack_MySQL

每天进步一点达MySQLmyisampack_MySQL

Jun 01, 2016 pm 12:59 PM

一、 简介

myisampack是一个压缩使用MyISAM引擎表的工具,一般会压缩40%~70%,当需要访问数据,服务器会将所需要的信息读入到内存中,所以当访问具体记录时,性能会更好,因为只需要解压一条记录

MySQL使用mmap()对变哦进行压缩映射,如果mmap()不工作,MySQL会返回到普通的读写文件操作

压缩后的表将会成为只读的,并且myisampack不支持分区表。

二、 命令格式

myisampack 选项 文件名

三、 常用参

--backup-b --backup 使用tbl_name .OLD备份数据文件

--force -f 产生一个压缩的表,即使它比原始表大,或如果以前调用myisampack的中间文件存在。(myisampack压缩表时在数据库目录中创建一个名为tbl_name.TMD的中间文件。如果杀掉myisampack,.TMD文件会被删除)。通常情况,如果myisampack发现tbl_name.TMD存在则退出并提示错误。用--force,myisampack则一定压缩表。

--join=big_tbl_name -j big_tbl_name 将命令行中的所有表联接为一个表big_tbl_name。将要连接的所有表必须有相等的结构(相同的列名和类型,相同的索引等等)。

--packlength=len,-p len 指定记录长度存储大小,以字节计。值应为1、2或者3。myisampack保存所有长度指针为1、2或者3字节的行。在大多数正常情况下,myisampack在开始压缩文件前可以确定准确的长度值,但在压缩过程中它可以提示它可能已经使用了一个短的长度。在这种情况下,myisampack输出一条提示,下次你压缩同一文件时,你可以使用更短的记录长度。

--silent,-s 沉默模式。只有发生错误时才写输出。

--test,-t 没有实际地压缩表,只是测试压缩。

--tmpdir=path,-T path 使用myisamchk创建临时文件的目录。

--verbose,-v 冗长模式。写压缩操作过程相关信息和其结果。

--version,-V 显示版本信息并退出。

--wait,-w 如果表正使用则等待并重试。如果用--skip-external-locking选项调用了mysqld服务器,如果在压缩过程中表可能被更新,调用myisampack不是一个好主意。

运行myisampack后,必须运行myisamchk以重新创建索引。此时,你也可以排序索引块并创建MySQL优化器需要的统计信息以更有效地工作: shell> myisamchk -rq --sort-index--analyze tbl_name.MYI 将压缩的表安装到MySQL数据库目录中后,应执行mysqladmin flush-tables以强制mysqld使用新的表。 要想解压缩一个压缩的表,使用myisamchk或isamchk的--unpack选项。

 

--help 帮助

 

四、 常用例子

1. myisampack压缩表

[root@localhosttest2]# ll -tr

总用量 180

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8556 7月 16 16:46 t1.frm

-rw-rw---- 1 mysql mysql 1024 7月 16 17:29 t1.MYI

-rw-rw---- 1 mysql mysql 161742 7月 16 17:29 t1.MYD

[root@localhost test2]# myisampack t1

Compressing t1.MYD: (23106 records)

- Calculating statistics

- Compressing file

85.68%

[root@localhosttest2]# ll -tr

总用量 44

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8556 7月 16 16:46 t1.frm

-rw-rw---- 1 mysql mysql 23167 7月 16 17:29 t1.MYD

-rw-rw---- 1 mysql mysql 1024 7月 16 17:30 t1.MYI

 

在Mysql中查询

mysql>show table status like 't1'\G;

*************************** 1. row***************************

Name: t1

Engine: MyISAM

Version: 10

Row_format: Fixed

Rows: 22857

Avg_row_length: 7

Data_length: 159999

Max_data_length: 1970324836974591

Index_length: 1024

Data_free: 0

Auto_increment: NULL

Create_time: 2015-07-16 16:46:17

Update_time: 2015-07-16 17:29:40

Check_time: NULL

Collation: latin1_swedish_ci

Checksum: NULL

Create_options:

Comment:

1 row in set (0.00 sec)

 

ERROR:

No query specified

 

mysql>show table status like 't1'\G;

*************************** 1. row***************************

Name: t1

Engine: MyISAM

Version: 10

Row_format: Fixed

Rows: 23177

Avg_row_length: 7

Data_length: 162239

Max_data_length: 1970324836974591

Index_length: 1024

Data_free: 0

Auto_increment: NULL

Create_time: 2015-07-16 16:46:17

Update_time: 2015-07-16 17:30:48

Check_time: NULL

Collation: latin1_swedish_ci

Checksum: NULL

Create_options:

Comment:

1 row in set (0.00 sec)

t8 lines: 7 columns: 9

2. myisampack备份数据库文件

[root@localhost test2]# ll

-rw-rw---- 1 mysql mysql 65 7月 16 16:40 db.opt

-rw-rw---- 1 mysql mysql 8572 7月 17 09:28 t1.frm

-rw-rw---- 1 mysql mysql 73 7月 17 09:50 t1.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:04 t1.MYI

-rw-rw---- 1 mysql mysql 217月 17 09:50 t1.OLD

-rw-rw---- 1 mysql mysql 8598 7月 17 10:10 t2.frm

-rw-rw---- 1 mysql mysql4344192 7月 17 10:11 t2.MYD

-rw-rw---- 1 mysql mysql 4955136 7月 17 10:11 t2.MYI

-rw-rw---- 1 mysql mysql 8572 7月 17 10:06 t3.frm

-rw-rw---- 1 mysql mysql 147456 7月 17 10:06 t3.ibd

-rw-rw---- 1 mysql mysql 8598 7月 17 10:11 t4.frm

-rw-rw---- 1 mysql mysql 4344192 7月 17 10:11 t4.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:11 t4.MYI

-rw-rw---- 1 mysql mysql 8598 7月 17 10:12 t5.frm

-rw-rw---- 1 mysql mysql 1996157 7月 17 10:12 t5.MYD

-rw-rw---- 1 mysql mysql 1024 7月 17 10:12 t5.MYI

-rw-rw---- 1 mysql mysql4344192 7月 17 10:12 t5.OLD

我们发现备份出来的数据文件与原来的文件大小一致,但是压缩后的数据文件会小一些

 

3. 向T5中插入数据

 

mysql> insert into t5(str_number)values(1);

ERROR 1036 (HY000): Table 't5' is read only


本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
2 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用Alter Table语句在MySQL中更改表? 如何使用Alter Table语句在MySQL中更改表? Mar 19, 2025 pm 03:51 PM

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

如何为MySQL连接配置SSL/TLS加密? 如何为MySQL连接配置SSL/TLS加密? Mar 18, 2025 pm 12:01 PM

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

您如何处理MySQL中的大型数据集? 您如何处理MySQL中的大型数据集? Mar 21, 2025 pm 12:15 PM

文章讨论了处理MySQL中大型数据集的策略,包括分区,碎片,索引和查询优化。

哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? 哪些流行的MySQL GUI工具(例如MySQL Workbench,PhpMyAdmin)是什么? Mar 21, 2025 pm 06:28 PM

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]

如何使用Drop Table语句将表放入MySQL中? 如何使用Drop Table语句将表放入MySQL中? Mar 19, 2025 pm 03:52 PM

本文讨论了使用Drop Table语句在MySQL中放下表,并强调了预防措施和风险。它强调,没有备份,该动作是不可逆转的,详细介绍了恢复方法和潜在的生产环境危害。

您如何用外国钥匙代表关系? 您如何用外国钥匙代表关系? Mar 19, 2025 pm 03:48 PM

文章讨论了使用外国密钥来代表数据库中的关系,重点是最佳实践,数据完整性和避免的常见陷阱。

如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? 如何保护MySQL免受常见漏洞(SQL注入,蛮力攻击)? Mar 18, 2025 pm 12:00 PM

文章讨论了使用准备好的语句,输入验证和强密码策略确保针对SQL注入和蛮力攻击的MySQL。(159个字符)

如何在JSON列上创建索引? 如何在JSON列上创建索引? Mar 21, 2025 pm 12:13 PM

本文讨论了在PostgreSQL,MySQL和MongoDB等各个数据库中的JSON列上创建索引,以增强查询性能。它解释了索引特定的JSON路径的语法和好处,并列出了支持的数据库系统。

See all articles