当前位置: 首页 > news >正文

网站建设要托管服务器滑县网站建设公司

网站建设要托管服务器,滑县网站建设公司,天河区做网站的公司,王占山事迹1. COMPACT行格式 COMPACT行格式是MySQL5.1的默认行格式.其结构示意图如下. 大体可以分为两部分. 记录的额外信息.这里面有包括变长字段长度列表,NULL值列表和记录头信息.记录的真实数据. (1).变长字段长度列表 MySQL支持一些变长的数据类型.比如VARCHAR(m), VA…

1. COMPACT行格式

COMPACT行格式是MySQL5.1的默认行格式.其结构示意图如下.

f1d1fc7c0c0643c0803d555be1e43332.png

大体可以分为两部分.

  • 记录的额外信息.这里面有包括变长字段长度列表,NULL值列表和记录头信息.
  • 记录的真实数据.

(1).变长字段长度列表

MySQL支持一些变长的数据类型.比如VARCHAR(m), VARBINARY(n), TEXT类型.这些数据类型修饰的列称为变长字段.变长字段中存储多少字节的数据不是固定的,所以我们在存储数据的时候也顺便把这些数据占用的字节数也存储起来.在COMPACT行格式中,把所有变长字段的真实数据占用的字节数都存放在记录的开头部位,从而形成变长字段长度列表.

这里存储的变长字段长度和字段顺序是反过来的.比如此处应该存放为060408.

CREATE TABLE compact_demo(
c1 VARCHAR(8),
c2 VARCHAR(8),
c3 CHAR(8),
c4 VARCHAR(8)
) charset=ascii ROW_FORMAT=COMPACT;INSERT INTO compact_demo
VALUES('zhangsan', 'lisi', 'wang5', 'ding1');

b23c63c65b0f4892947bd4d16e8b8b1a.png

(2). NULL值列表

compact格式会把可以为null值的列统一管理起来,存放在一个标记为null值的列表中.如果表中没有允许存储null值的列,则null值列表也就不存在了.

之所以要存储null值,是因为数据是需要对齐的.如果没有表明出来null值的位置,就有可能查询数据的时候发生混乱.如果使用一个特定的符号放到相应数据位表示null值的话,会很浪费空间,所以干脆直接在行数据开头开辟一处空间专门用来记录该行记录哪些是空数据,哪些是非空.

二进制位为1时,该列的值为null.为0时则该列的值为非空.

如果某字段明确了是非空的(比如NOT NULL/PRIMARY KEY),那么null值列表就不管这些字段了.

(3).记录头信息

记录头信息占有5个字节大小.用于描述记录的一些属性.

147c91ca8c9947a3a951edfc4e3fc39f.png

1. 删除标记位(Delete Flag):占1位,表示记录是否被标记为删除。在InnoDB中,记录被删除时并不是立即物理删除,而是通过设置这个标志位来标记记录为已删除,这样可以快速“删除”记录且不影响后续的插入操作。2. 最小记录标记位(Min Record Marker):占1位,仅在页内最小记录上设置为1,表明这是页内用户记录中的最小记录。3. 最大记录标记位(Max Record Marker):占1位,仅在页内最大记录上设置为1,表明这是页内用户记录中的最大记录。4. heap_no:占4位,表示记录在页内的堆编号,用于标识记录在页中插入的顺序。5. next_record:占16位或24位(取决于行格式),记录指向下一个记录的指针,用于遍历页内的记录链表。在Compact和Redundant行格式中通常是16位,在DYNAMIC和COMPRESSED行格式中可能使用24位以适应更大的页大小。6. n_owned:占4位,在B+树的非叶节点中,表示子页的数量;在聚集索引的叶节点中,表示指向同一行的辅助索引记录数量。7. record type:占3位,表示记录类型,常见的有:- 0:普通用户记录。- 1:目录项记录,用于B+树的内部节点。- 2:最小记录(Infimum)- 3: 最大记录(Supremum),这两个特殊的记录用来界定用户记录的边界,不存储实际用户数据。

这些字段的作用以后细谈.

(4). 记录的真实数据

记录的真实数据除了我们自己定义的列的数据外,还有三个隐藏列.

b51d6aeed5c54f9e81198bec49187a71.png

这些列的真实名称其实是 : DB_ROW_ID, DB_TRX_ID, DB_ROLL_PTR.

值得注意的是,除了第一个row_id,其他两个都是必须的.这是为什么呢?

原因我们讲过,创建聚簇索引时,我们优先选择用户自定义的主键作为主键,如果无,则会选择一个非空且唯一键作为主键,如果无,那么InnoDB会为表默认添加一个名为row_id的列作为隐藏列作为主键.

2. DYNAMIC/COMPRESSED行格式

MySQL5.7和8.0默认的行格式都是dynamic.

这两个行格式只有在行溢出这种情况下,有所区别,简单介绍一下行格式.

我们知道一个页的大小一般是16kb.也就是16384字节.而一个类型为varchar(m)的列最多可以存储65533个字节.这样就可能出现了一个页存放不下一条记录.这种情况叫行溢出.

  • 在COMPACT/REDUNTANT行格式中,对于占用存储空间非常大的列,在记录的真实数据处只会存储该列的一部分数据,把其他剩余数据分散存储在几个其他的页中进行分页存储.然后记录的真实数据用20个字节存储指向这些页的地址.从而可以找到剩余数据所在的页.
  • 在DYNAMIC/COMPRESSED行格式中,对于存放在blog中的数据采用了完全行溢出的方式.比如在数据页中只存放20个字节的地址,实际数据都放在溢出页中.
http://www.yayakq.cn/news/492580/

相关文章:

  • 哪里有网站制作建设网站关键词的确定
  • 西安市城乡建设网官方网站找别人做网站可以提供源码吗
  • 泰安专业网站开发公司下载建设银行官方网站下载安装
  • 网站开发的著作权归谁论坛网站 备案
  • 网站设计机构文档网页设计教程免费
  • 杭州化妆品网站建设室内设计师网上接单的平台
  • 企业网站快照更新wordpress搬迁后变英文
  • 怎么做网站架构东营二手房出售信息网
  • 儿童摄影网站模板外包公司做网站怎么样
  • 网站建设与管理案例教程第三版答案什么网站做ppt赚钱
  • 上海做网站就用乐云seo十年用微信微博网站来做睡眠经济
  • php做网站验证码的设计深圳中高风险地区
  • 甘肃省城乡和住房建设厅网站广告公司名字怎么取
  • 博客网站如何设计小米发布会官网
  • 深圳做网站的价格网站结合微信
  • 做网站被捉网站建设费属于无形资产吗
  • 登录网站软件怎么做asp是网站开发吗
  • 网页ui设计网站手机网站模板建站
  • 手机上网网站建设网站建设性能指标
  • 做企业网站服务商瀑布流响应式网站模板
  • 公司网站建设设计公司排名免费一键生成证件照
  • 优质做网站公司中国建筑网测
  • 石柱县建设局网站河池城乡住房和建设局网站
  • 5网站建站网站导航栏三根横线怎么做的
  • 主流建站公司利用网站制作网页
  • 狠狠做新网站公司名字查重系统
  • 专门代写平台超级seo工具
  • 行业门户网站建设方案书wordpress自定义字段
  • 手机上怎么上传网站吗宝安logo设计
  • 做商城网站简单吗具有价值的常州做网站