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

MySQL的聚簇索引和非聚簇索引的区别以及示例

MySQL的聚簇索引和非聚簇索引

聚簇索引

聚簇索引是一种索引结构,它与数据行存储在一起,即索引的叶子节点就是数据行本身。在MySQL中,主键索引就是一种典型的聚簇索引

涉及情况

当查询需要按照主键或唯一索引进行精确查找时,会涉及到聚簇索引。

数据结构

聚簇索引的数据结构是B+树,它的叶子节点存储了完整的数据行

速度

由于数据行和索引在一起,所以在使用聚簇索引进行查询时,速度比非聚簇索引更快。

非聚簇索引

非聚簇索引是一种索引结构,它的叶子节点存储的是指向数据行的指针,而不是数据行本身。在MySQL中,普通索引就是一种非聚簇索引

涉及情况

当查询需要按照非主键或非唯一索引进行查找时,会涉及到非聚簇索引。

数据结构

非聚簇索引的数据结构同样是B+树,但它的叶子节点存储的是指向数据行的指针

速度

由于非聚簇索引的叶子节点存储的是指针而不是完整的数据行,所以在使用非聚簇索引进行查询时,速度相对较慢。

对比

  • 聚簇索引的叶子节点存储完整的数据行,速度更快,适合于按主键或唯一索引进行精确查找的情况,不需要回表
  • 非聚簇索引的叶子节点存储的是指向数据行的指针,速度相对较慢,适合于按非主键或非唯一索引进行查找的情况,需要回表

例子

假设有一个名为students的学生表,包含以下字段:

  • id (主键)
  • name
  • age
  • gender
  • class_id (班级ID)
CREATE TABLE students (id INT PRIMARY KEY,name VARCHAR(50),age INT,gender VARCHAR(10),class_id INT,INDEX idx_name (name),INDEX idx_class_id (class_id)
);

在这个例子中,id字段是主键,因此它将会作为聚簇索引。同时,我们创建了两个非聚簇索引,分别是按照nameclass_id字段创建的索引。当进行按照nameclass_id进行查询时,将会涉及到非聚簇索引的使用。

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

相关文章:

  • 裸机开发(1)-汇编基础
  • 解决log4j多个日志都写到一个文件
  • YOLOv5 目标计数 | 图片上绘制计数结果
  • 【网络安全/CTF】unseping 江苏工匠杯
  • 鼠标悬浮在树组件节点上展示当前节点名称
  • 构建创新学习体验:企业培训系统技术深度解析
  • 云计算:现代技术的基本要素
  • (1)(1.11) SiK Radio v2(一)
  • 视频号视频怎么保存到手机相册?
  • 【svn】win11最新svn每天自动化定时update、commit,隐藏窗口,定时脚本编写
  • 【YOLO系列】YOLOv3代码详解(四):模型脚本model.py
  • Elasticsearch可视化平台Kibana [ES系列] - 第498篇
  • Python深度学习029:pytorch中常用的模块或方法
  • MongoDB创建和查询视图(二)
  • 【MYSQL】MYSQL 的学习教程(七)之 慢 SQL 优化思
  • iOS - 真机调试的新经验
  • thinkphp6.0的workerman在PHP8.0下报错
  • SQL语句分类
  • C# Onnx yolov8 pokemon detection
  • Flink电商实时数仓(六)
  • 本地部署Jellyfin影音服务器并实现远程访问内网影音库
  • 【React Native】第一个Android应用
  • 解决IOS transform rotate后文字无法显示,backface-visibility导致@click事件失效
  • Nature | 大型语言模型(LLM)能够产生和发现新知识吗?
  • 多维时序 | MATLAB实CNN-Mutilhead-Attention卷积神经网络融合多头注意力机制多变量时间序列预测
  • Nature 新研究发布,GPT 驱动的机器人化学家能够自行设计和进行实验,这对科研意味着什么?
  • Ai画板原理
  • 【hacker送书第11期】Python数据分析从入门到精通
  • 华为OD机试 - 精准核酸检测(Java JS Python C)
  • 智能优化算法应用:基于材料生成算法3D无线传感器网络(WSN)覆盖优化 - 附代码