当前位置: 首页 > news >正文

八股面试——数据库——索引

索引的概念

B+树的概念:



索引的作用

聚簇索引与非聚簇索引

聚簇索引就是主键值,在B+树上,通过主键大小(数据在B+树叶子节点按主键顺序排序)寻找对应的叶子节点,叶子节点保存的一整条记录。

非聚簇索引(又叫二次索引)是其他属性,在B+树上,通过该属性大小寻找对应的叶子节点,叶子节点保存的是对应的主键,然后再通过主键寻找记录。

覆盖索引与MySQL超大分页处理
覆盖索引

覆盖索引是指我们当前使用该索引查找所返回的列,在该索引中已经全部找到。(主键一定是覆盖索引)。

MySQL超大分页处理

超大分页问题

当分页数较大,查询速率会大幅度降低:

超大分页查询优化

下述SQL语句通过覆盖索引+子查询保证不会产生回表查询,从而加快查询速度。

索引创建的原则

总结

聚簇索引与非聚簇索引

聚簇索引是主键,非聚簇索引是其他属性。

覆盖索引与MySQL超大分页处理

覆盖索引是指我们当前使用该索引查找所返回的列,在该索引中已经全部找到。(主键一定是覆盖索引)。

MySQL超大分页处理方法是通过覆盖索引+子查询。

索引创建原则

索引失效情况

http://www.lryc.cn/news/333755.html

相关文章:

  • 【二分查找】Leetcode 二分查找
  • Python+Vuecil笔记
  • C语言关于随机数知识点的总结
  • 网络应用层和传输层
  • Vue3:优化-从响应式数据中获取纯数据
  • C#.手术麻醉系统源码 手麻系统如何与医院信息系统进行集成?
  • 学习CSS Flexbox 玩flexboxfroggy flexboxfroggy1-24关详解
  • springboot项目如何配置跨域?
  • 实现第一个动态链接库 游戏插件 成功在主程序中运行 dll 中定义的类
  • 算法第三十九天-验证二叉树的前序序列化
  • Rust---复合数据类型之字符串与切片(2)
  • iOS 应用内网络请求设置代理
  • 什么是MariaDB
  • 【面试八股总结】传输控制协议TCP(三)
  • 今年过去了多少天?(switch)
  • 提升团队工程交付能力,从“看见”工程活动和研发模式开始
  • 前端学习之DOM编程案例:全选反选案例
  • golang map
  • 设计模式:享元模式案例
  • pandas(day5)
  • 如何注册midjourney账号
  • 探索数据结构:特殊的双向队列
  • 16_I2C库函数
  • 十八、Rust gRPC 多 proto 演示
  • 【Linux】Linux64位环境下编译32位报错skipping incompatible的解决办法
  • vue指令v-model
  • CentOS安装MySQL数据库
  • 从B2B转向B2B2C模式:工业品牌史丹利百得的转型历程
  • Redis群集模式和rsync远程同步
  • JAVA—抽象—定义抽象类Converter及其子类WeightConverter