总结
各模块功能及依赖总结
最后, 我们再通过几个例子, 来看一下NYADB的各个模块之间是怎么相互工作的.
先总结一下各个模块提供的操作,
DM: insert(x), update(x), read(x)
DM提供了针对数据项(data item)的基本插入, 更新, 读取操作, 且这些操作是原子性的. DM会直接对数据库文件进行读写.
TM: begin, commit(T), abort(T), state(T)
TM提供了针对事务的开始, 提交, 回滚操作, 同时提供了对数据项状态的查询操作.
VM: insert(X), update(X), read(X), delete(X)
VM提供了针对记录(entry)的增删查改操作, VM在内部为每条记录维护多个版本, 并根据不同的事务, 返回不同的版本. VM对这些实现, 是建立在DM和TM的各个操作上的.
TBM: execute(statement)
TBM就是非常高层的模块了, 他能直接执行用户输入的语句(statement), 然后进行执行. TBM对语句的执行是建立在VM和IM提供的各个操作上的.
IM: value search(key), insert(key, value)
IM提供了对索引的基本操作.
read语句的流程
假设现在要执行read * from student where id = 2012141461290, 并且在id上已经建有索引. 执行过程如下:
- TBM接受语句, 并进行解析.
- TBM调用IM的search方法, 查找对应记录所在的地址.
- TBM调用VM的read方法, 并将地址作为参数, 从VM中尝试读取记录内容.
- VM通过DM的read操作, 读取该条记录的最新版本.
- VM检测该版本是否对该事务可见, 其中需要TM的state方法.
- 如果可见, 则返回该版本的数据.
- 如果不可见, 则读取上一个版本, 并重复5, 6, 7.
- TBM取得记录的二进制内容后, 对其进行解析, 还原出记录内容.
- TBM将记录的内容返回给客户端.
insert语句的流程
假设现在要执行insert into student values “zhangyuanjia” 2012141461290这条语句. 执行过程如下:
- TBM接受语句, 并进行解析.
- TBM将values的值, 二进制化.
- TBM利用VM的insert操作, 将二进制化后的数据, 插入到数据库.
- VM为该条数据建立版本控制, 并利用DM的insert操作, 将数据插入到数据库.
- DM将数据插入到数据库, 并返回其被存储的地址.
- VM将得到的地址, 作为该条记录的handler, 返回给TBM.
- TBM计算该条语句的key, 并将handler作为data, 并调用IM的insert, 建立索引.
- IM利用DM提供的read和insert等操作, 将key和data存入索引中.
- TBM返回客户端插入成功的信息.
自动测试
暂略