每天进步一点达——MySQL——myisampack
一、 简单介绍
myisampack是一个压缩使用MyISAM引擎表的工具,通常会压缩40%~70%,当须要訪问数据。server会将所须要的信息读入到内存中。所以当訪问详细记录时,性能会更好,由于仅仅须要解压一条记录
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选项调用了mysqldserver。假设在压缩过程中表可能被更新,调用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
每天进步一点达——MySQL——myisampack的更多相关文章
- 在写一点关于MySQL的知识,感觉自己mmd
DBMS(Database Management System)数据库管理系统 包括有DDL(数据定义语言)和DML(数据操纵语言)以及DCL(数据库控制语言) 数据库设计方法: 1.需求分析阶段 ...
- mysql数据库史上最详细起步教程(1)
本文主要讲解mysql的操作,尽量保证步骤的详细与清晰,希望能帮到大家. 1.登录后进行数据库的创建:create database lf(数据库名); (一定要记住分号,mysql在语句的结束符就 ...
- mysql分区
<?php /* 分区 目录 18.1. MySQL中的分区概述 18.2. 分区类型 18.2.1. RANGE分区 18.2.2. LIST分区 18.2.3. HASH分区 18.2.4. ...
- 转-MySQL教程-写的很详细,赞一个
原帖地址:https://www.w3cschool.cn/mysql/,谢谢原帖大人 MySQL是什么? MySQL安装 MySQL示例数据库 MySQL导入示例数据库 MySQL基础教程 MySQ ...
- SQL Server和MySQL数据库
导读:接下来的网上商城的项目,需要用到MySQL数据库了.这个对于我来说,是一个新接触的东西,按照惯例,在刚开始学习一个东西的时候,先从宏观上去了解它.本篇博客,先介绍SQL Server的基本内容, ...
- Mysql 和 Postgresql(PGSQL) 对比
Mysql 和 Postgresql(PGSQL) 对比 转载自:http://www.oschina.net/question/96003_13994 PostgreSQL与MySQL比较 MySQ ...
- PostgreSQL与MySQL对比
都属于开放源码的一员,性能和功能都在高速地提高和增强.MySQL AB的人们和PostgreSQL的开发者们都在尽可能地把各自的数据库改得越来越好,所以对于任何商业数据库使用其中的任何一个都不能算是错 ...
- PostgreSQL 与 MySQL 相比,优势何在?
一. PostgreSQL 的稳定性极强, Innodb 等引擎在崩溃.断电之类的灾难场景下抗打击能力有了长足进步,然而很多 MySQL 用户都遇到过Server级的数据库丢失的场景——mysql系统 ...
- Mysql bench执行sql语句批量操作数据所遇到的问题
一.错误 rror Code: 1175. You are using safe update mode and you tried to update a table without a WHERE ...
随机推荐
- iOS 并发:NSOperation 与调度队列入门(1)
一直以来,并发都被视为 iOS 开发中的「洪水猛兽」.许多开发者都将其视为危险地带,唯恐避之而不及.更有谣传认为,多线程代码应该尽力避免.笔者同意,如果你对并发的了解不够深入,就容易造成危险.但是,危 ...
- Java 应用发布后,需要关注的7个性能指标
在某个重大发布之后,都需要记录相应的指标,本文介绍了最重要的几个 Java 性能指标,包括响应时间和平均负载等.为理解应用程序在生产环境中如何运行,就需要遵循一些 Java 性能指标. 在以前,当软件 ...
- ***Java多线程发展简史
http://blog.jobbole.com/28297/ 本文来自四火的博客(@RayChase),由@_Zhijun 推荐 这篇文章,大部分内容,是周五我做的一个关于如何进行Java多线程编程的 ...
- 上次的AJAX定时刷新多ID不正确,这次请教了高手之后补全
关键是setInterval无法传递参数,所以用了匿名函数再包裹一下就好了. //重置发布进度 function resetPercent(id_data){ $.ajax({ url:'/autod ...
- SPRING IN ACTION 第4版笔记-第三章ADVANCING WIRING-006-给bean运行时注入值(Environment,Property文件)
一. 直观的给bean注入值如下: @Bean public CompactDisc sgtPeppers() { return new BlankDisc( "Sgt. Pepper's ...
- Document字段发生变化后,报的错
2016-10-11 15:27:47,828 [ERROR] [main] SpringApplication:838 - Application startup failedorg.springf ...
- Webform——购物车
购物车主要实现的功能: ①在主页面可以将所有商品显示出来,包括价格,库存. ②点击购买可以累加产品,如果是同一种产品,只会累加每种产品的数量. ③查看购物车,可以查看明细,包括所购物品的名称,价格,数 ...
- c程序设计语言_习题1-13_统计输入中单词的长度,并且根据不同长度出现的次数绘制相应的直方图
Write a program to print a histogram of the lengths of words in its input. It is easy to draw the hi ...
- 去除浏览器下jquey easyui datagrid、combotree 缓存问题
在页面脚本中加入以下内容即可: $.ajaxSetup ({ cache: false //关闭AJAX相应的缓存 });
- 关于ListView的 addHeaderView(...) 方法
在代码中使用 listView .addHeaderView(...) 方法可以在ListView组件上方添加上其他组件,并且连结在一起像是一个新组件.如果多次使用 .addHeaderView(.. ...