第五节:从一条记录说起——InnoDB记录结构

《MySQL 是怎样运行的:从根儿上理解 MySQL》第五节:从一条记录说起——InnoDB记录结构

准备工作

    现在只知道客户端发送请求并等待服务器返回结果。
    MySQL什么方式来访问这些数据?
    MySQL服务器上负责对表数据的读取和写入工作的部分是存储引擎。
    什么格式存放?
    真实的数据在不同存储引擎中存放的格式一般是不同的。

InnoDB页简介

    InnoDB将数据划分为若干个页,以页作为磁盘和内存的交互的基本单位,InnoDB也的大小一般为16KB。    

InnoDB行格式

    InnoDB存储引擎有四种不用类型的行个格式,Compact、Redundant、Dynamic和Compressed行格式
    指定行格式的语法
        CREATE TABLE 表名 (列的信息) ROW_FORMAT=行格式名称
        ALTER TABLE 表名 ROW_FORMAT=行格式名称
        案例:
            CREATE TABLE record_format_demo (
                  c1 VARCHAR(10),
                  c2 VARCHAR(10) NOT NULL,
                  c3 CHAR(10),
                  c4 VARCHAR(10)
            )CHARSET=ASCII ROW_FORMAT=COMPACT;
    COMPACT行格式
        一行记录包含
            记录的额外信息
                变长字段长度列表:
                    记录每个变长列数据占用的字节长度,倒叙存放。
                    WML记录,还要再学习。
                    可以不需要,比如:表的每个列都不是变长的数据类型就没有。
                NULL值列表:
                    首先统计允许从存储NULL的列,主键列、被NOT NULL修饰的列不可以存储NULL值。
                    表中么有允许NULL值的列,NULL值列表也就不存在了。
                    允许存储NULL的列对应一个二进制位。
                        二进制位的值为1,表示该列值为NULL。
                        二进制位的值为0,表示该列值不为NULL。
                    二进制位按照逆序排列,第一个列和最后一个二进制位对应。
                    MySQL规定NULL值列表必须用整数个字节位表示,如果使用的二进制位不是整数个字节,则在高位补0
                记录头信息:
                    五个固定字节组成,其他后面学习。
            记录的真实数据
                隐藏列,除了真实数据MySQL还会添加三个隐藏列。
                    row_id:可选。在没有主键,也没有定义unique键的列,InnoDB才会为表添加。
                    transaction_id:必选,事物ID
                    roll_pointer:必选,回滚指针
                数据列
                    非变成字段,没存储地方,空格字符填充。
                    存储为null的列,在前面的NULL值列表中有存储,不会再记录,节省空间。
        CHAR(M)列的存储格式
            列采用定长字符集,该列占用的字节数不会被加到变长字段长度列表,
            如果采用变长字符集时,该列占用的字节数也会被加到变长字段长度列表。
            用字符集最大的字节占空间,防止后面修改数据需要的空间变大而重新分配空间导致碎片。
    Redundant行格式:MySQL5.0以前的一种行格式(没多看 略)
        一行记录包含
            记录的额外信息
                字段长度偏移列表
                    没有变长,说明会记录所有的列(包括隐藏列)。
                    偏移:表示它是采用两个相邻值的差值来计算各个列值的长度。
                记录头信息
                    
            记录真实数据

行溢出数据,不太理解,后面再学习一次。

        VARCHAR(M)最多能存储的数据?
            计算方式不太理解,后面再学习一次。
        记录数据太多产生的溢出
            一个页的大小一般是16kb,也就是16384字节,可能一行记录超过16384个字节。

作者总结

    1.页是MySQL中磁盘和内存交互的基本单位,也是MySQL是管理存储空间的基本单位。
    2.指定修改行格式的语法如下:
        CREATE TABLE 表名 (列的信息) ROW_FORMAT=行格式名称
        ALTER TABLE 表名 ROW_FORMAT=行格式名称
    3.InnoDB现在定义了4种行格式
        一个也一般是16KB,当记录中的数据太多,当前也放不下的时候,会把多余的数据存储到其他页中,称为行溢出。

脑图地址:方便有需要的同学高清看
http://naotu.baidu.com/file/a0133241fae5042adac6387c7a2a4a7b?token=fb9dfd8fefbdc019


第五节:从一条记录说起——InnoDB记录结构