InnoDB--------查询IOTB+Tree的高度-创新互联

1. 背景

河南网站建设公司成都创新互联,河南网站设计制作,有大型网站制作公司丰富经验。已为河南千余家提供企业网站建设服务。企业网站搭建\成都外贸网站建设公司要多少钱,请找那个售后服务好的河南做网站的公司定做!

  * 在InnoDB存储引擎中,表都是根据主键顺序组织存放的,这种存储方式的表称为索引组织表(index organized table IOT)。

  * 在InnoDB存储引擎中,每张表都有个主键(Primary key),如果在创建表时没有地定义主键,则InnoDB存储引擎会选择表中符合条件的列或隐式创建主键。

InnoDB--------查询IOT B+ Tree的高度

2. 环境

mysql> select version(); +------------+ | version()  | +------------+ | 5.6.36-log | +------------+ 1 row in set (0.02 sec) mysql> select database(); +------------+ | database() | +------------+ | mytest     | +------------+ 1 row in set (0.00 sec) mysql> show tables; +------------------+ | Tables_in_mytest | +------------------+ | customer         | | district         | | history          | | item             | | new_orders       | | order_line       | | orders           | | stock            | | warehouse        | +------------------+ 9 rows in set (0.00 sec) mysql> show variables like 'innodb_page_size'; +------------------+-------+ | Variable_name    | Value | +------------------+-------+ | innodb_page_size | 8192  | +------------------+-------+ 1 row in set (0.04 sec)

3. 查询

  * 查询每张表primary key对应的root page_no

mysql> select t.table_id table_id, t.name table_name, i.page_no root_page_no  from information_schema.INNODB_SYS_INDEXES i, information_schema.INNODB_SYS_TABLES t  where i.table_id = t.table_id  and i.name = 'PRIMARY'  and t.name like 'mytest/%'; +----------+-------------------+--------------+ | table_id | table_name        | root_page_no | +----------+-------------------+--------------+ |       22 | mytest/customer   |            3 | |       21 | mytest/district   |            3 | |       27 | mytest/item       |            3 | |       24 | mytest/new_orders |            3 | |       26 | mytest/order_line |            3 | |       25 | mytest/orders     |            3 | |       28 | mytest/stock      |            3 | |       20 | mytest/warehouse  |            3 | +----------+-------------------+--------------+ 8 rows in set (0.04 sec)

  * 查询order_line表数据量

mysql> select count(1) from order_line; +----------+ | count(1) | +----------+ |  6001615 | +----------+ 1 row in set (9.03 sec)

 * 通过表数据文件order_line.ibd获取高度 [跳过 root_page_no * innodb_page_size + 64, 获取2字节长度就是树的高度]

  由此可得树的高度为3, 高度标记从0开始

[root@localhost src]# hexdump -s 24640 -n 2 -C /data/mysql_data_6/mytest/order_line.ibd; 00006040  00 02                                             |..| 00006042

4. B+Tree

高度非叶节点数叶节点数数据行数占用空间
10146816.0KiB
211203> 563 thousand18.8MiB
312041447209> 677 million22.1GiB
414484131740992427> 814 billion25.9TiB

5. xxx

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


文章标题:InnoDB--------查询IOTB+Tree的高度-创新互联
转载注明:http://csdahua.cn/article/dsiiji.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流