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

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.kler.cn/a/303992.html

相关文章:

  • 【juc】AbstractQueuedSynchronized为什么采用双向链表
  • 监控录音如何消除杂音?降低录音噪音的五个技巧
  • 软考:去中心化的部署有什么特点
  • 云防护单节点2T抗攻击能力意味着什么?
  • 《重学Java设计模式》之 原型模式
  • ReactPress:构建高效、灵活、可扩展的开源发布平台
  • 为什么网站加载速度总是那么不尽如人意呢?(网站优化篇)
  • 2024.9.14(RC和RS)
  • Docker操作MySQL
  • 互联网环境下CentOS7部署K8S
  • LNMP的简单安装(ubuntu)
  • Artec Leo协助定制维修管道,让石油和天然气炼油厂不停产
  • vue3开发uniapp转字节小程序注意事项
  • 《C++PrimerPlus》第10章:类和对象
  • go语言开发windows抓包工具
  • 在centos上搭建syslog服务端
  • 详情攻略来了!浏览网站记录怎么查?一文读懂这3种实用方法
  • Vue3 响应式工具函数isRef()、unref()、isReactive()、isReadonly()、isProxy()
  • 火焰检测算法、明烟明火检测、烟火检测算法
  • dirty pages , swapiness 查看SWAP占用进程
  • 线性代数 第六讲 特征值和特征向量_相似对角化_实对称矩阵_重点题型总结详细解析
  • 【原创】java+springboot+mysql疫情期间在线答疑系统设计与实现
  • Word使用手册
  • MDK keil STM32 局部变量不能查看值,显示为not in scope
  • 数业智能心大陆探索生成式AIGC创新前沿
  • Mysql JSON结果不能IN