数据库篇-01-MySQL篇-课程介绍_哔哩哔哩_bilibili
?
节点可以自动平衡保证log2 n的查找复杂度.
但因为是二叉树,数据多了层数还会多。
所以找一个多叉树
是一个多叉树,比较矮胖,对比红黑树查找效率更高。
存放的数字可以看成是区间界限。
但是如果你要查的值在叶子上,你一路向下查,非叶子节点上的数据也会被加载出来,所以多次磁盘读写了不需要的数据,所以磁盘代价低。
---->B+树非叶子上只有指针没有数据,所以不必一路加载数据,只要到叶子节点上加载一次就行。
三大优势:
1.不用像B树一样路过非叶子节点还得读一下节点数据,B+树的非叶就是指针导向的作用,不会浪费磁盘读写。
2.查找都在叶子上,基本效率都在logn,稳定
3.范围查找方便,比如找(6,30),先找到叶子上的6,然后通过双向链表一次性查到范围内的所有数据,避免dfs
?
数据库篇-06-优化-覆盖索引、超大分页优化_哔哩哔哩_bilibili
?
?
就是要按你联合索引的顺序来。
要用右边的左边的必须有且顺序不能乱。如果中间断开,只有前面符合最左原则的部分用到索引。
看key和keylen两列知道用了多少索引,索引走的越多,keylen越大
?
?
问题还有一个丢失更新?
redo log是物理日志,记录的是正向的操作
?undo log是逻辑日志,记录和操作相反的语句,用来撤销。
这个trx_id是上面的db_trx_id,代表上一次插入或者修改记录的事务号?
如果这个号不在活跃集合里,代表该事务修改完成提交已经结束
?
redis的主从同步是增量同步和全量同步
mysql靠的是二进制日志binlog