查看某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. Start my cnBlogs

    Compared to CSDN blog, althought it's my first time to use CNBlog,i felt it makes me more comfortabl ...

  2. windows下编译ffmpeg

    windows 编译ffmpeg 搞过很多次,每次总是磕磕碰碰,从头到尾不能一直顺利,浪费一些时间.终究起原因,都是当时记得,过段时间就忘了.好记性不如烂笔头,大好周末晚上,闲暇无事,记录最近一次编译 ...

  3. 邻结矩阵的建立和 BFS,DFS;;

    邻结矩阵比较简单,, 它的BFS,DFS, 两种遍历也比较简单,一个用队列, 一个用数组即可!!!但是邻接矩阵极其浪费空间,尤其是当它是一个稀疏矩阵的时候!!!-------------------- ...

  4. eclipse中加放js文件报js语法错误解决办法

    1) eclipse设置         window->preference-> JavaScript -> Validator->Errors/Warnings->E ...

  5. 【BZOJ】【1934】【SHOI 2007】Vote 善意的投票

    网络流/最小割 简单题= =直接利用最小割的性质: 割掉这些边后,将所有点分成了两部分(两个连通块),我们可以假定与S相连的是投赞成票,与T相连的是投反对票. 那么如果一个小朋友原本意愿是睡觉,那么连 ...

  6. 【BZOJ】【1013】【JSOI2008】球形空间产生器sphere

    高斯消元 高斯消元模板题 /************************************************************** Problem: 1013 User: Tun ...

  7. Unity3d游戏中添加移动MM支付SDK问题处理

    原地址:http://www.tuicool.com/articles/I73QFb 由于移动mm的SDK将部分资源文件放在jar包中,导致Unity无法识别,提示failed to find res ...

  8. Observer Pattern

    Motivation We can not talk about Object Oriented Programming without considering the state of the ob ...

  9. hdu 1063 Exponentiation

    求实数的幂,这个用C++写的话有点长,但是用Java写就非常方便了…… );            System.out.println(an);        }    }}

  10. hdu 1812 Count the Tetris

    高精度+polya原理可以搞定 思路: 设边长为n的正方形,c种颜色.旋转只有 0,90,180,270度三种旋法.旋0度,则置换的轮换数为n*n旋90度,n为偶数时,则置换的轮换数为n*n/4,n为 ...