查看某page中含有的记录个数

#define    PAGE_N_HEAP     4    /* number of records in the heap,
                bit =flag: new-style compact page format */

/*************************************************************//**
Gets the number of records in the heap.
@return    number of user records */
UNIV_INLINE
ulint
page_dir_get_n_heap(
/*================*/
    const page_t*    page)    /*!< in: index page */
{
    return(page_header_get_field(page, PAGE_N_HEAP) & 0x7fff);
}

/*************************************************************//**
Reads the given header field. */
UNIV_INLINE
ulint
page_header_get_field(
/*==================*/
    const page_t*    page,    /*!< in: page */
    ulint        field)    /*!< in: PAGE_LEVEL, ... */
{
    ut_ad(page);
    ut_ad(field <= PAGE_INDEX_ID);

    return(mach_read_from_2(page + PAGE_HEADER + field));
}

#define    PAGE_HEADER    FSEG_PAGE_DATA    /* index page header starts at this offset */

#define FSEG_PAGE_DATA        FIL_PAGE_DATA

#define FIL_PAGE_DATA        38
InnoDB将所有的记录存放在数据库页中(也可以称为数据块)。一般情况下,所有的页大小都是16KB。
      数据页中不仅仅包含实际的记录,还包含其它的一些内容,比如文件头以及文件尾等等。
 InnoDB的页包含以下几个部分:
1)      Fil Header:文件头
2)      Page Header:页头
3)      Infimum+Supremum Records:最小虚记录以及最大虚记录
4)      User Records:用户记录
5)      Free Space:自由堆
6)      Page Directory:目录槽
7)      Fil Trailer:文件尾
     从这几个部分,我们可以看到。页中的2与6是与页管理有关,页中的1和7与文件管理有关。其中的3、4、5是记录相关的。每个页一旦分配,一定具有最小虚记录与最大虚记录,可以分别想像成无穷小、无穷大。当用户插入一条记录,就会从5(自由堆)中分配一块空间用来存储该记录。
 
1 Fil Header(文件头)
   文件头由8个部分组成,见表1:
                              表1:文件头的组织形式
名称
长度
含义
FIL_PAGE_SPACE
4
space id
FIL_PAGE_OFFSET
4
页号
FIL_PAGE_PREV
4
上一页
FIL_PAGE_NEXT
4
下一页
FIL_PAGE_LSN
8
日志序列号
FIL_PAGE_TYPE
2
页类型
FIL_PAGE_FILE_FLUSH_LSN
8
文件的日志序列号,仅文件的第一页的此字段有效
FIL_PAGE_ARCH_LOG_NO
4
归档日志文件号
 
 
2 Page Header(页头)
   页头由14个部分组成,见表2:
                               表2:文件头的组织形式
名称
长度
含义
PAGE_N_DIR_SLOTS
2
记录槽的数量,初始值为2,因为页至少具有最小虚记录与最大虚记录
PAGE_HEAP_TOP
2
指向堆中的第一条记录
PAGE_N_HEAP
2
堆记录的数量,初始值为2
PAGE_N_FREE
2
指向第一个空闲记录
PAGE_GARBAGE
2
被删除记录的总字节数
PAGE_LAST_INSERT
2
指向最后一个插入的记录
PAGE_DIRECTION
2
记录顺序
PAGE_N_DIRECTION
2
连续同方面插入的数量
PAGE_N_RECS
2
用户记录的数量
PAGE_MAX_TRX_ID
8
更改此页的最高事务ID(仅仅对二级索引有效)
PAGE_LEVEL
2
该页在索引中的层次(页节点是0)
PAGE_INDEX_ID
8
所属的索引ID
PAGE_BTR_SEG_LEAF
10
索引页节点段
PAGE_BTR_SEG_TOP
10
索引内节点段
 
 
3 Infimum+Supremum Records(最小虚记录以及最大虚记录)
   最小虚拟记录与最大虚拟记录,既是所谓的负无穷大、正无穷大。这两个记录是在页创建时创建的,并且永远不会被删除。它们的作用在于作为查询的屏障,避免越界。
 
4 User Records(用户记录)
  在该区域中,将可以找到所有用户插入的记录。有两种方式来查找用户记录,一种为有序,另外一种为无序。
   InnoDB不会在该区域按照记录进行B树的key排序(这会导致频繁的数据移动),所以,插入时是直接将新行插入现有行的后面(从自由堆的顶部分配空间),或者使用空闲记录的空间(空闲记录即被删除的记录,记录被删除后,并不立即回收该记录所占的空间)。
 但是,B树的定义是记录必须按照key值进行排序,因此每个记录都含有一个指针(next字段)指向下一条记录(以key值排序)。换句话说,这些记录有一个单向链表。所以,InnoDB在查找时可以按照key排序的方式进行查找。
 
5 Free Space(自由堆)
   自由堆,可以从该堆上为新记录分配所需空间。
 
6 Page Directory(目录槽)
   和其它数据库不同的是,InnoDB并不会为每一个记录分配一个目录。每六个记录分配一个目录。
 
7 Fil Trailer(文件尾)
  文件尾记录的是文件的LSN。
 
 

函数 page_dir_get_n_heap的更多相关文章

  1. 函数lock_rec_create

    /*********************************************************************//** Creates a new record lock ...

  2. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  3. 探究javascript对象和数组的异同,及函数变量缓存技巧

    javascript中最经典也最受非议的一句话就是:javascript中一切皆是对象.这篇重点要提到的,就是任何jser都不陌生的Object和Array. 有段时间曾经很诧异,到底两种数据类型用来 ...

  4. JavaScript权威指南 - 函数

    函数本身就是一段JavaScript代码,定义一次但可能被调用任意次.如果函数挂载在一个对象上,作为对象的一个属性,通常这种函数被称作对象的方法.用于初始化一个新创建的对象的函数被称作构造函数. 相对 ...

  5. C++对C的函数拓展

    一,内联函数 1.内联函数的概念 C++中的const常量可以用来代替宏常数的定义,例如:用const int a = 10来替换# define a 10.那么C++中是否有什么解决方案来替代宏代码 ...

  6. 菜鸟Python学习笔记第一天:关于一些函数库的使用

    2017年1月3日 星期二 大一学习一门新的计算机语言真的很难,有时候连函数拼写出错查错都能查半天,没办法,谁让我英语太渣. 关于计算机语言的学习我想还是从C语言学习开始为好,Python有很多语言的 ...

  7. javascript中的this与函数讲解

    前言 javascript中没有块级作用域(es6以前),javascript中作用域分为函数作用域和全局作用域.并且,大家可以认为全局作用域其实就是Window函数的函数作用域,我们编写的js代码, ...

  8. 复杂的 Hash 函数组合有意义吗?

    很久以前看到一篇文章,讲某个大网站储存用户口令时,会经过十分复杂的处理.怎么个复杂记不得了,大概就是先 Hash,结果加上一些特殊字符再 Hash,结果再加上些字符.再倒序.再怎么怎么的.再 Hash ...

  9. JS核心系列:浅谈函数的作用域

    一.作用域(scope) 所谓作用域就是:变量在声明它们的函数体以及这个函数体嵌套的任意函数体内都是有定义的. function scope(){ var foo = "global&quo ...

随机推荐

  1. 1833: [ZJOI2010]count 数字计数 - BZOJ

    Description给定两个正整数a和b,求在[a,b]中的所有整数中,每个数码(digit)各出现了多少次.Input输入文件中仅包含一行两个整数a.b,含义如上所述.Output输出文件中包含一 ...

  2. <顶>vim快捷键映射Map使用

    问题描述: 使用vim中的快捷键映射map,可以自定义快捷键 问题解决: (1)vim模式 (2)map前缀 (3)删除映射Map (4)使用示例 (5)查看快捷键映射 命令行---:verbose ...

  3. 【POJ】【2096】Collecting Bugs

    概率DP/数学期望 kuangbin总结中的第二题 大概题意:有n个子系统,s种bug,每次找出一个bug,这个bug属于第 i 个子系统的概率为1/n,是第 j 种bug的概率是1/s,问在每个子系 ...

  4. VS2010 创建WindowsService服务

    1.新建一个Windows 服务 2.添加Installer 这一步很重要,在处理完你的业务逻辑后需要添加一个Installer才能是你的Windows服务被安装. 在VS中添加Installer 右 ...

  5. 《head first java 》读书笔记(二)

    Updated 2014/03/27 P402-P454 Updated 2014/04/03 P454- 世界三大首席管理器: border, flow, box borderLayout: 五个区 ...

  6. HDU2594 Simpsons’ Hidden Talents 字符串哈希

    最近在学习字符串的知识,在字符串上我跟大一的时候是没什么区别的,所以恶补了很多基础的算法,今天补了一下字符串哈希,看的是大一新生的课件学的,以前觉得字符串哈希无非就是跟普通的哈希没什么区别,倒也没觉得 ...

  7. POJ 1852

    #include <iostream> using namespace std; int main() { //freopen("acm.acm","r&qu ...

  8. Floodlight 防火墙是如何起作用的

    前言 用mininet + floodlight搭建好环境之后,运行flooglight,然后在mininet中建立网络拓扑,建好之后,pingall,所有host之间可以ping通. 然后向控制器f ...

  9. lintcode 中等题: reverse linked list II 翻转链表II

    题目 翻转链表 II 翻转链表中第m个节点到第n个节点的部分 样例 给出链表1->2->3->4->5->null, m = 2 和n = 4,返回1->4-> ...

  10. 欧拉工程第60题:Prime pair sets

    题目链接 五个数,任意两个数的任意链接后的数还是质数 满足这个条件的最小五个数的和是多少? 结果:26033 纯暴力破解: package projecteuler51to60; import jav ...