欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

每天进步一点达MySQLmyisampack_MySQL

程序员文章站 2022-04-29 23:45:52
...
一、 简介

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