DB

管理数据库的类

  • file_entry:dir page的元素,保存不同文件对应的page
  • directory_page:dir page的专用结构体,里面有个初始长度为0的variable sized array用来保存file entry
  • first_page:保存整个数据库的信息,包括整个数据库有多少page和dir page的结构体

整个数据库构造是这样的:整个数据库是一个超大文件,第0页是header page,包含整个数据库的全局信息;第1页是dir page,后面的page保存的是表示整个数据库中分配了空间的page的bit map

  • DB:创建新的数据库,接收名字和页的数量
    1. 拷贝数据库名
    2. 打开文件
    3. 将整个文件按照页的数量进行扩张,写满0(用lseek扩张,write写0)
    4. 用buffer manager的pinPage创建header_page,page id为0,empty=true(这里使用了强制转换)
    5. 初始化这个header page里的dir page,unpin掉它
    6. 将后面所有的bit map都填满1
  • DB(没有num_pages):打开已有数据库
    1. 打开文件
    2. pin住header page,设置empty=false,这样buffer manager会把文件里的第0页读进指针
    3. 根据读到的内容设置好数据库信息,unpin
  • db_destroy:干掉数据库
    1. 关闭文件
    2. 用unlink删掉文件
  • allocate_page:给一堆页分配连续空间
    1. pin住每个bit map所在的page
    2. pin完之后在这个map里找足够长的run,对应足够多的空page
    3. 如果找得到,将起始页的id写进参数返回
  • deallocate_page:顾名思义
  • add_file_entry:给dir page增加file entry,接收文件名和文件对应第一页的page id
    • 找有足够空间的dir page和它对应的header page,找不到就新建
    • 将这个file entry的起始页id和对应文件名设好
    • unpin
  • delete_file_entry:顾名思义
    • 找遍每个dir page的每一个entry,直到找到文件名对的为止
    • 找到之后通过修改内容清空里面的数据,和删掉一样
  • get_file_entry:找到对应文件的第一页的page id
    • 也是找找找。。。
  • read_page:将制定page id的内容读进pageptr
    • 用lseek在文件里定位到这一页的起始处(pageno*pagesize)
    • 读进对应长度的内容
  • write_page:将pageptr的内容写进page id
    • 和read_page差不多
  • set_bits:批量设置bit map
    • 各种位操作看不懂> <
  • init_dir_page:初始化dir page
    • 自己的next_page和entry里所有的pagenum都设为INVALID_PAGE

MINIBASE源代码阅读笔记之DB的更多相关文章

  1. MINIBASE源代码阅读笔记之buffer manager

    BufDesc frame 们的 descriptor(见BufHashTbl注释),包括 pageNo: 这个 frame 在文件里的id,page number prevframe: -1 表示此 ...

  2. MINIBASE源代码阅读笔记之heapfile

    Heapfile 用来管理heap file里的dir page们 成员 _firstDirPageId:这个文件的第一个dir page _ftype:文件类型 _file_deleted:删除的时 ...

  3. MINIBASE源代码阅读笔记之HFPage

    HFPage heap file的page的类 成员 slot_t:用来表示页里的slot,包括offset和length slot[]:倒着生长的slot array slotCnt:有多少已用sl ...

  4. Mongodb源代码阅读笔记:Journal机制

    Mongodb源代码阅读笔记:Journal机制 Mongodb源代码阅读笔记:Journal机制 涉及的文件 一些说明 PREPLOGBUFFER WRITETOJOURNAL WRITETODAT ...

  5. CI框架源代码阅读笔记5 基准測试 BenchMark.php

    上一篇博客(CI框架源代码阅读笔记4 引导文件CodeIgniter.php)中.我们已经看到:CI中核心流程的核心功能都是由不同的组件来完毕的.这些组件类似于一个一个单独的模块,不同的模块完毕不同的 ...

  6. CI框架源代码阅读笔记3 全局函数Common.php

    从本篇開始.将深入CI框架的内部.一步步去探索这个框架的实现.结构和设计. Common.php文件定义了一系列的全局函数(一般来说.全局函数具有最高的载入优先权.因此大多数的框架中BootStrap ...

  7. CI框架源代码阅读笔记2 一切的入口 index.php

    上一节(CI框架源代码阅读笔记1 - 环境准备.基本术语和框架流程)中,我们提到了CI框架的基本流程.这里再次贴出流程图.以备參考: 作为CI框架的入口文件.源代码阅读,自然由此開始. 在源代码阅读的 ...

  8. Spark源代码阅读笔记之DiskStore

    Spark源代码阅读笔记之DiskStore BlockManager底层通过BlockStore来对数据进行实际的存储.BlockStore是一个抽象类,有三种实现:DiskStore(磁盘级别的持 ...

  9. Java Jdk1.8 HashMap源代码阅读笔记二

    三.源代码阅读 3.元素包括containsKey(Object key) /** * Returns <tt>true</tt> if this map contains a ...

随机推荐

  1. 基于 Quartz.NET 实现可中断的任务

    基于 Quartz.NET 实现可中断的任务 Quartz.NET 是一个开源的作业调度框架,非常适合在平时的工作中,定时轮询数据库同步,定时邮件通知,定时处理数据等. Quartz.NET 允许开发 ...

  2. 2017 Multi-University Training Contest - 2

    HDU 6045 #pragma comment(linker, "/STACK:102400000,102400000") #include <cstdio> #in ...

  3. POJ 3260 完全背包+多重背包+思维

    传送门:https://vjudge.net/problem/20465/origin 题意:你有n种钞票,面值为c[i],数量为v[i],便利店老板有无数张面值为c[i]的钞票,问你买一个价值为T的 ...

  4. Java面试题:多继承

    招聘和面试对开发经理来说是一个无尽头的工作,虽然有时你可以从HR这边获得一些帮助,但是最后还是得由你来拍板,或者就像另一篇文章"Java 面试题:写一个字符串的反转"所说: 面试开 ...

  5. hadoop 安装教程

    本教程由厦门大学数据库实验室 / 给力星出品,转载请注明.本教程适合于原生 Hadoop 2,包括 Hadoop 2.6.0, Hadoop 2.7.1 等版本,主要参考了官方安装教程,步骤详细,辅以 ...

  6. 动态规划:LIS优化

    对于1D/1D动态规划来说,理论时间复杂度都是O(n^2)的,这种动态规划一般都可以进行优化,贴一篇文章 https://wenku.baidu.com/view/e317b1020740be1e65 ...

  7. [洛谷P2750] [USACO5.5]贰五语言Two Five

    洛谷题目链接:[USACO5.5]贰五语言Two Five 题目描述 有一种奇怪的语言叫做"贰五语言".它的每个单词都由A-Y这25个字母各一个组成.但是,并不是任何一种排列都是一 ...

  8. C11工具类:字符转换

    1.数值类型和字符串转换 1.1 数值转换为字符 std::string to_string(int value); std::string to_string(long value); std::s ...

  9. SDUT 3929

    Description 蓝色空间号和万有引力号进入了四维水洼,发现了四维物体--魔戒. 这里我们把飞船和魔戒都抽象为四维空间中的一个点,分别标为 "S" 和 "E&quo ...

  10. JodaTime报时区异常错误

    在将爬下来的网页解析需要的字段批量入口的时候(逻辑类似下面): @Test public void test_001(){ String TIME = "1990-04-15"; ...