MINIBASE源代码阅读笔记之DB
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:创建新的数据库,接收名字和页的数量
- 拷贝数据库名
- 打开文件
- 将整个文件按照页的数量进行扩张,写满0(用lseek扩张,write写0)
- 用buffer manager的pinPage创建header_page,page id为0,empty=true(这里使用了强制转换)
- 初始化这个header page里的dir page,unpin掉它
- 将后面所有的bit map都填满1
- DB(没有num_pages):打开已有数据库
- 打开文件
- pin住header page,设置empty=false,这样buffer manager会把文件里的第0页读进指针
- 根据读到的内容设置好数据库信息,unpin
- db_destroy:干掉数据库
- 关闭文件
- 用unlink删掉文件
- allocate_page:给一堆页分配连续空间
- pin住每个bit map所在的page
- pin完之后在这个map里找足够长的run,对应足够多的空page
- 如果找得到,将起始页的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的更多相关文章
- MINIBASE源代码阅读笔记之buffer manager
BufDesc frame 们的 descriptor(见BufHashTbl注释),包括 pageNo: 这个 frame 在文件里的id,page number prevframe: -1 表示此 ...
- MINIBASE源代码阅读笔记之heapfile
Heapfile 用来管理heap file里的dir page们 成员 _firstDirPageId:这个文件的第一个dir page _ftype:文件类型 _file_deleted:删除的时 ...
- MINIBASE源代码阅读笔记之HFPage
HFPage heap file的page的类 成员 slot_t:用来表示页里的slot,包括offset和length slot[]:倒着生长的slot array slotCnt:有多少已用sl ...
- Mongodb源代码阅读笔记:Journal机制
Mongodb源代码阅读笔记:Journal机制 Mongodb源代码阅读笔记:Journal机制 涉及的文件 一些说明 PREPLOGBUFFER WRITETOJOURNAL WRITETODAT ...
- CI框架源代码阅读笔记5 基准測试 BenchMark.php
上一篇博客(CI框架源代码阅读笔记4 引导文件CodeIgniter.php)中.我们已经看到:CI中核心流程的核心功能都是由不同的组件来完毕的.这些组件类似于一个一个单独的模块,不同的模块完毕不同的 ...
- CI框架源代码阅读笔记3 全局函数Common.php
从本篇開始.将深入CI框架的内部.一步步去探索这个框架的实现.结构和设计. Common.php文件定义了一系列的全局函数(一般来说.全局函数具有最高的载入优先权.因此大多数的框架中BootStrap ...
- CI框架源代码阅读笔记2 一切的入口 index.php
上一节(CI框架源代码阅读笔记1 - 环境准备.基本术语和框架流程)中,我们提到了CI框架的基本流程.这里再次贴出流程图.以备參考: 作为CI框架的入口文件.源代码阅读,自然由此開始. 在源代码阅读的 ...
- Spark源代码阅读笔记之DiskStore
Spark源代码阅读笔记之DiskStore BlockManager底层通过BlockStore来对数据进行实际的存储.BlockStore是一个抽象类,有三种实现:DiskStore(磁盘级别的持 ...
- Java Jdk1.8 HashMap源代码阅读笔记二
三.源代码阅读 3.元素包括containsKey(Object key) /** * Returns <tt>true</tt> if this map contains a ...
随机推荐
- yii2框架-yii2局部关闭(开启)csrf的验证
(1)全局使用,我们直接在配置文件中设置enableCookieValidation为true request => [ 'enableCookieValidation' => true, ...
- django 自定义认证
在Django中自定义身份验证 Django 自带的认证系统足够应付大多数情况,但你或许不打算使用现成的认证系统.定制自己的项目的权限系统需要了解哪些一些关键点,即Django中哪些部分是能够扩展或替 ...
- Linux之GDB调试介绍与应用20170601
一.GDB调试命令 描述 backtrace(或bt) 查看各级函数调用及参数 finish 连续运行到当前函数返回为止,然后停下来等待命令 frame(或f) 帧编号 选择栈帧 info(或i) ...
- dorado重置按钮事件
// @Bind #btnReset.onClick!function(self, arg) { var subNo = view.get("#dsQueryCriteria"). ...
- lightoj 1148 Mad Counting(数学水题)
lightoj 1148 Mad Counting 链接:http://lightoj.com/volume_showproblem.php?problem=1148 题意:民意调查,每一名公民都有盟 ...
- 单例 ------ C++实现
基础知识掌握: 单例考虑三点:内存何时释放.运行速度如何.多线程下能否保证只有一个实例 如果获取对象的返回值类型是引用,返回值赋值给变量而不是引用会进行对象的拷贝,这样就会出现两个对象,可以把显示声明 ...
- python使用snappy压缩
今天在网上找了很久,终于找到1个snappy压缩命令行,记录下来: 1.wget https://bootstrap.pypa.io/get-pip.py 2.python ./get-pip.py ...
- 深度学习voc数据集图片resize
本人新写的3个pyhton脚本. (1)单张图片的resize: # coding = utf-8 import Image def convert(width,height): im = Image ...
- [DeeplearningAI笔记]序列模型1.10-1.12LSTM/BRNN/DeepRNN
5.1循环序列模型 觉得有用的话,欢迎一起讨论相互学习~Follow Me 1.10长短期记忆网络(Long short term memory)LSTM Hochreiter S, Schmidhu ...
- ArrayList和Array区别
1)精辟阐述:可以将 ArrayList想象成一种“会自动扩增容量的Array”. 2)Array([]):最高效:但是其容量固定且无法动态改变: ArrayList: 容量可动态增长:但牺 ...