Mariadb 数据库进阶学习一 表的重新认识

         通过简单的Sql语句创建表后,表是怎么存储的,以什么的方式进行存储的,占的磁盘空间是怎么算的?就是想通过深入学习,了解其内部构造结构。

MariaDB [db_test]> create table t8 (id int,sex char(1),username varchar(100),age tinyint,brithday date);
Query OK, 0 rows affected (0.028 sec)

        在磁盘中找到对应的数据表文件:

[root@172 /]# cd /var/lib/mysql/db_test
[root@172 db_test]# ls
db.opt  t2.frm  t2.ibd  t3.frm  t3.ibd  t5.frm  t5.ibd  t6.frm  t6.ibd  t7.frm  t7.ibd  t8.frm  t8.ibd

     两份文件对应的大小分别是:t8.frm 633B,t8.ibd 96KB (98.304B) ,借助hexdump命令查看此两文件

hexdump 参数
-C 每一字节以16进制显示,一行共16个字节,显示十六进制存储的文本内容
-b 每一字节以八进制显示,一行共16个字节,一行开始以十六进制显示偏移值;
  0000000 177 105 114 106 002 001 001 000 000 000 000 000 000 000 000 000
-c 每一字节以ASCII字符显示,其余同上;
  0000000 177 E L F 002 001 001 \0 \0 \0 \0 \0 \0 \0 \0 \0
-n 只解释指定长度字节
  单位:默认十进制,0x或0X开头则为16进制,0开头则为8进制。默认为字节,b则为512字节,k则为1024字节,m则为1048576字节
-d 双字节十进制显示
-o 双字节八进制显示
-v 去除中间显示的“*”字符
-x 双字节十六进制显示
-e 格式化参数

       具体查看:

[root@172 db_test]# hexdump -C  t8.frm
00000000  fe 01 0a 0c 12 00 56 00  01 00 44 03 00 00 10 00  |......V...D.....|  fe 01 固定头部 0a 0c 12 版本号
00000010  3a 01 00 00 00 00 00 00  00 00 00 02 08 00 09 00  |:...............|  IO_SIZE 
00000020  00 05 00 00 00 00 21 00  00 00 00 00 00 00 00 10  |......!.........|
00000030  00 00 00 3c 88 01 00 10  00 00 00 00 00 00 00 00  |...<............|
00000040  00 10 ad b8 52 30 3d b5  11 eb ac 4b 0c da 41 1d  |....R0=....K..A.|
00000050  8a 5a b0 01 00 00 00 00  00 00 02 00 ff 00 00 00  |.Z..............|
00000060  00 00 00 00 00 00 ff 00  00 00 00 20 20 20 00 00  |...........   ..|
00000070  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
000001a0  00 00 06 00 49 6e 6e 6f  44 42 00 00 00 00 00 00  |....InnoDB......|      // 表存储的存储引擎
000001b0  94 01 94 01 00 00 00 00  00 00 00 00 00 00 00 00  |................|
000001c0  00 00 00 00 00 00 00 00  00 00 00 00 00 00 00 00  |................|
*
000002b0  00 00 05 00 00 00 48 01  00 00 3a 01 1f 00 00 00  |......H...:.....|   // 字段属性
000002c0  00 00 00 00 00 00 50 00  16 00 05 00 00 00 00 00  |......P.........|
000002d0  00 00 00 0b 00 02 00 00  1b 80 00 00 00 03 21 00  |..............!.|    03---int
000002e0  00 00 00 00 03 00 06 00  00 00 80 00 00 00 fe 21  |...............!|    fe---char
000002f0  00 00 00 00 00 2c 01 09  00 00 00 80 00 00 00 0f  |.....,..........|    of---varchar
00000300  21 00 00 00 00 00 04 00  37 01 00 0b 80 00 00 00  |!.......7.......|
00000310  01 21 00 00 00 00 00 0a  00 38 01 00 70 80 00 00  |.!.......8..p...|
00000320  00 0e 21 00 00 ff 69 64  ff 73 65 78 ff 75 73 65  |..!...id.sex.use|     // 表的字段
00000330  72 6e 61 6d 65 ff 61 67  65 ff 62 72 69 74 68 64  |rname.age.brithd|
00000340  61 79 ff 00                                       |ay..|
00000344

   字符集对应的16进制码: 21=utf8 08=latin1  1c=GBK

   这篇文章有更详细的解释:https://dev.mysql.com/doc/internals/en/frm-file-format.html

 

posted @ 2020-12-14 17:14  中级菜鸟  阅读(118)  评论(0编辑  收藏  举报