数据库索引,B树,B+树,group by,order by区别

数据库索引能加速查询但影响写操作,基于B树或B+树的数据结构实现。聚集索引是表的主键对应的数据结构,而非聚集索引仅保存主键值。覆盖索引允许不通过聚集索引获取数据。ORDER BY用于数据排序,GROUP BY用于按列分组。
摘要由CSDN通过智能技术生成

数据库索引

加索引后查询会变快,但是写入,删除,修改会变慢,增加了数据库的存储空间

类似于书的目录。

先了解下平衡树(b tree或者b+ tree).

如果数据库的表有主键,那么表在磁盘上的存储结构就由整齐排列的结构变为树状结构。也就是平衡树结构,也就是整个表变成了一个索引。这样被称为聚集索引。因此一个表只能有一个聚集索引。

为什么索引会给查询以外的操作带来影响?

平衡树必须始终维持在一个稳定的状态。增删改操作都会修改平衡树中各节点的数据内容,破坏了树的结构。

非聚集索引:

也是采用平衡树作为索引的数据结构,非聚集索引互相之间不存在关联。

区别:通过聚集索引可以查找到数据对应的值,非聚集索引是查到数据对应的主键值,在使用主键的值通过聚集索引查到需要的数据。所以最终都会用到主键值通过聚集索引来定位元素。聚集索引是通往真是数据的唯一路径。

但是

有一种例外,可以不通过聚集索引就能查出所需要的数据。那就是覆盖索引。

就是平时说的多复合索引和多字段索引查询。

参考:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值