实验环境:
OS:Ubuntu 10.04
数据库版本:Mysql 5.5.18
安装路径 :/opt/mysql/
数据存放位置:/opt/mysql/data
实验一:Mysql将为所有的数据库创建一个单独的文件夹
首先,cd到数据目录下:
- root@liu-pc:~# cd /opt/mysql/data/
查看当前文件夹下都有那些文件夹:
- mysql performance_schema test
在Mysql中每个数据库都对应一个文件,以上的3个文件的做用分别是:
mysql库:其中的host,db,user,tables_priv,columns_priv这5张表是用来存储权限信息的。还有其他一些表暂不深究。
performance_schema库:不是很清楚。
test库:测试库,这个库中没有表。没有什么实际功能,供测试用。
链接Mysql,并创建新的数据库myisam_test:
- root@liu-pc:/opt# ./mysqlslave/bin/mysql -uroot
- mysql> create database myisam_test;
- Query OK, 1 row affected (0.00 sec)
这个时候在打开数据存放的文件夹并ls:
- mysql performance_schema test myisam_test
可以看到多了一个文件夹:myisam_test。mysql会为每一个数据库创建一个文件夹。
cd到此文件夹,并查看都有那些文件 :
- root@liu-pc:/opt/mysql/data# cd myisam_test/
-
root@liu-pc:/opt/mysql/data/myisam_test# ls
-
db.opt
可以看到myisam_test文件夹只有文件db.opt。这个文件存储的是一些和myisam_test相关的配置文件,暂不深入。
实验二:MyISAM引擎存储表信息将用到的文件
*.frm(存储表结构信息)
*.MYI(存储表索引信息)
*.MYD(存储表数据信息)
链接数据库并创建t表:
- root@liu-pc:/opt# ./mysqlslave/bin/mysql -uroot
- mysql> use myisam_test;
- Database changed
- mysql> create table t(id int auto_increment primary key,name char(20)) engine=myisam;
- Query OK, 0 rows affected (0.06 sec)
打开文件夹myisam_test,并查看其中的文件信息(ls -l)
- root@liu-pc:/opt/mysql/data/myisam_test# ls -l
- total 20
- -rw-rw---- 1 mysql mysql 65 2011-12-07 15:43 db.opt
- -rw-rw---- 1 mysql mysql 8586 2011-12-07 15:55 t.frm
- -rw-rw---- 1 mysql mysql 0 2011-12-07 15:55 t.MYD
- -rw-rw---- 1 mysql mysql 1024 2011-12-07 15:55 t.MYI
可以看到多了 t.frm t.MYD t.MYI 三个文件,其中t.frm是用来存放表结构信息的。
t.MYI 是用来存放索引信息的,因为t表有主键索引,其占用了1kb的大小。
t.MYD是用来存放数据信息的,因为表中没有数据,所有其大小为0.
下面分别向表中添加字段,数据查看上述三个文件的大小变化情况:
在表t中添加字段***,并查看t.frm文件大小变化情况:
- mysql> alter table t add column *** char(2);
-
Query OK, 0 rows affected (0.04 sec)
-
Records: 0 Duplicates: 0 Warnings: 0
查看t.frm文件大小:
- root@liu-pc:/opt/mysql/data/myisam_test# ls -l t.frm
-
-rw-rw---- 1 mysql mysql 8614 2011-12-07 16:12 t.frm
t.frm文件有原来的8586增加到8614。
在表中插入数据,查看t.MYD和t.MYI文件的大小变化:
- mysql> insert into t(name) values('zhangsan');
-
Query OK, 1 row affected (0.00 sec)
查看t.MYD和t.MYI文件的大小:
- root@liu-pc:/opt/mysql/data/myisam_test# ls -l t.MY*
-
-rw-rw---- 1 mysql mysql 54 2011-12-07 16:40 t.MYD
-
-rw-rw---- 1 mysql mysql 3072 2011-12-07 16:40 t.MYI
可以看到这两个文件所着空间都变大了。