DDIA学习笔记

1.关系模型和文本模型

常见的mysql的表就是关系模型,通过相同的键把多个表联系起来,在进行相关查询时很方便。

文本模型比如用jsonl文件存储的数据,用字符串的字段来标明是哪个字段,特点是不能区分整数浮点数以及精度,不过在局部性上比关系模型具有优势

2.图模型

属性图的两种存储方法,一种是利用关系模型去存储图的属性,一种是利用三元组去存储,三元组即主谓宾,谓语和宾语可以是关系和节点,也可以是属性和属性值。

3.Bitcask

顺序存储的模型,基于顺序写这种哪怕是删除信息也是记录一行删除记录作为墓碑,对应的就是查任何数据都需要全局扫描,除了删除,更新也是追加写因此也是需要看全局才能确定。

对于它的直接改进引出了SStable,即顺序索引的追加写,乍一看顺序和追加写是矛盾的,实际上是因为在内存用Btree或者红黑树来排序写,对于内存操作定时存入磁盘。

这两者在磁盘中都有压缩和合并的过程来避免磁盘空间用尽。

文件合并的过程中不影响对数据的读取,因此这种日志顺序记录的存储结构支持压缩合并与使用并行。

4.BTree

不强制要求顺序写,同时索引有序的情况支持在内存中稀疏存储索引。

相关推荐
sheeta199816 小时前
苍穹外卖Day05笔记
笔记
想搞艺术的程序员16 小时前
Java Survivor区学习笔记
java·笔记·学习·垃圾回收
吃杠碰小鸡16 小时前
学习英语的思路性问题
学习
不能隔夜的咖喱16 小时前
all-in-rag零散的笔记(自存/持续更新)
笔记
-Springer-16 小时前
STM32 学习 —— 个人学习笔记9-2(USART串口数据包 & 串口收发 HEX 及 文本 数据包)
笔记·stm32·学习
celeste031016 小时前
Redis Summary
linux·运维·服务器·redis·笔记
会编程的李较瘦16 小时前
【C语言程序设计学习】一、C语法基础
c语言·开发语言·学习
zzh08116 小时前
nginx安全笔记
笔记·nginx·安全
困死,根本不会17 小时前
【C 语言】指针学习笔记:从底层原理到实战应用
c语言·开发语言·笔记·学习·算法
努力努力再努力...17 小时前
学习Multipath多路径
学习