mit 6.830通关小结

本文总结了MIT 6.830数据库实验室的体验,包括lab1到lab6的主要内容:从基本数据结构到事务处理、B+树索引和日志恢复。实验难度逐渐提升,lab4和lab5最具挑战性。文中还提到一些未深入研究的优化点,如并发控制、死锁检测和索引并发,并分享了相关的学习资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前提: 我做的是最新版的6.830 lab

架构图

在这里插入图片描述

实验

  1. lab1 实现基本的数据结构
    tuple, page, tupleDesc, iterator等等,难度不大
  2. lab2 实现scan iterator
    基于scan iterator 来实现各种聚合函数,比如avg,count,sum,join等
  3. lab3 join 优化
    建立一个优化模型, 按照主键,非主键,scan 表代价,直方图等进行成本估计,根据估计值来确定多表join的顺序
  4. lab 4 事务以及锁
    这一章相对较难,要自己实现一个简单的读写锁,但是6.830中简化了,实现了page-level的锁,粒度比较粗,还有多种死锁的情况,test很给力,建议在写的时候一定要看清楚是哪个transaction 拿到了哪些page的哪些lock,而且这里的代码会影响到后面的lab 5、6,这里主要是按照两阶段锁协议并且no steal / force 的策略
  5. lab 5 B+ 树索引
    实现B+树索引,插入、删除、修改,难点在于要把B+树结构以及这三种操作逻辑要捋清楚,还有父节点,子节点;叶子兄弟节点,非叶子节点的指针问题,以及一些边界条件。
  6. lab 6 实现基于 log的ro
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值