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

76-mysql的聚集索引和非聚集索引区别

MySQL中的聚集索引和非聚集索引的主要区别在于它们的存储方式和使用方式。

聚集索引(Clustered Index):

  • 聚集索引的叶子页包含了行的全部数据。

  • 每个表只能有一个聚集索引,因为一个表中的数据只能按照一种方式存储。

  • 当你查询的列在聚集索引中,那么MySQL不需要进行额外的查找就能直接获取数据

非聚集索引(Non-Clustered Index):

  • 非聚集索引的叶子页包含了行的主键值。

  • 非聚集索引的叶子页同时包含了一个书签(bookmark),该书签指向聚集索引中的对应行

  • 当你查询的列不在非聚集索引中时,MySQL需要通过非聚集索引找到聚集索引中的数据

实例代码:

CREATE TABLE People (PersonID int NOT NULL,FirstName varchar(30) NOT NULL,LastName varchar(30) NOT NULL,BirthDate datetime NOT NULL,PRIMARY KEY (PersonID),INDEX (LastName, FirstName, BirthDate)
);

在这个例子中,PRIMARY KEY (PersonID)创建了聚集索引,而INDEX (LastName, FirstName, BirthDate)创建了非聚集索引。如果查询中使用到PersonID(聚集索引),那么可以直接从索引中获取数据。而如果查询中使用到LastNameFirstNameBirthDate(非聚集索引列),则需要通过非聚集索引先找到聚集索引,再获取数据行。

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

相关文章:

  • 每日一题——第八十八题
  • 【创作活动】学习使用哪个编程工具让你的工作效率翻倍?
  • 基于STM32C8T6的CubeMX:HAL库点亮LED
  • 职业院校数据科学与大数据技术专业人工智能实训室建设方案
  • JavaScript网页设计案例分析
  • 2024.9.15周报
  • QT模型视图结构1
  • Ubuntu20+Noetic+cartographer_ros编译部署
  • linux-L3-linux 复制文件
  • Kotlin:1.9.0 的新特性
  • golang实现从服务器下载文件到本地指定目录
  • C++数据结构-树的概念及分类介绍(基础篇)
  • 职场 Death Note
  • Vue3.0组合式API:computed计算属性、watch监听器、watchEffect高级监听器
  • RAII 与 std::lock_guard 在 C++ 中的应用:自动化互斥锁管理与线程安全
  • 风格汇:奢华风格在UI设计中如何被定义的。
  • Vue2 qrcode+html2canvas 实现二维码的生成和保存
  • GEE 教程:利用Google Dynamic数据进行逐月指定区域的土地分类数据提取分析
  • Nginx 负载均衡:优化网站性能与可扩展性的利器
  • 【Python基础】Python错误和异常处理(详细实例)
  • 如何查看串口被哪个程序占用?截止目前最方便的方法
  • 深入理解SpringBoot(一)----SpringBoot的启动流程分析
  • MySql基础-单表操作
  • 【STM32系统】基于STM32设计的SD卡数据读取与上位机显示系统(SDIO接口驱动、雷龙SD卡)——文末资料下载
  • SpringBoot开发——整合Redis
  • OpenCV结构分析与形状描述符(17)判断轮廓是否为凸多边形的函数isContourConvex()的使用
  • P5425 [USACO19OPEN] I Would Walk 500 Miles G
  • Java高级Day41-反射入门
  • 在Linux系统上使用Docker部署java项目
  • 【C++】标准库IO查漏补缺