MySQL_8.一级索引,二级索引概述

news/2024/6/18 21:41:47 标签: mysql, 数据库

1.一级索引
索引和数据存储在一起,都存储在同一个B+tree中的叶子节点。一般主键索引都是一级索引

2.二级索引
二级索引树的叶子节点存储的是主键而不是数据。也就是说,在找到索引后,得到对应的主键,再回到一级索引中找主键对应的数据记录。

3.一级索引和二级索引的关系:回表
一级索引可以单独存在,二级索引不能单独存在,必须依附于一级索引,这叫做“回表”。

4.二级索引优缺点
优点:
(1)减少数据冗余
(2)减少行移动或者数据页分裂时二级索引的维护工作,当数据需要更新的时候,二级索引不需要修改,只需要修改一级索引,
一个表只能有一个一级索引,其他的都是二级索引,这样只需要修改一级索引就可以了,不需要重新构建二级索引
缺点:
根据二级索引查找行的完整数据需要回表

5.创建二级索引
(1)创建二级索引:

CREATE INDEX [index name] ON [table name]([column name]);


(2)或者

ALTER TABLE [table name] ADD INDEX [index name]([column name]);


注:在MySQL中,CREATE INDEX 操作被映射为 ALTER TABLE ADD_INDEX。

6.例二级索引格式
例如创建如下一张表:

CREATE TABLE users(
    id INT NOT NULL, 
    name VARCHAR(20) NOT NULL,
    age INT NOT NULL, 
    PRIMARY KEY(id) 
    );


新建一个以age字段的二级索引:

ALTER TABLE users ADD INDEX index_age(age);


MySQL会分别创建主键id的聚簇索引和age的二级索引:
在MySQL中主键索引的叶子节点存的是整行数据,而二级索引叶子节点内容是主键的值。

7.二级索引的检索过程
在MySQL的查询过程中,SQL优化器会选择合适的索引进行检索,在使用二级索引的过程中,因为二级索引没有存储全部的数据,
假如二级索引满足查询需求(一般来说,比如只查id和当前列属性),则直接返回,即为覆盖索引,反之则需要回表去主键索引(聚簇索引)查询。

例如执行

SELECT * FROM users WHERE age=35;


在MySQL中,创建一张表时会默认为主键创建聚簇索引,B+树将表中所有的数据组织起来,即数据就是索引主键所以在InnoDB里,
主键索引也被称为聚簇索引,索引的叶子节点存的是整行数据。而除了聚簇索引以外的所有索引都称为二级索引,二级索引的叶子节点内容是主键的值。
 


http://www.niftyadmin.cn/n/5256627.html

相关文章

python——第十六天

面向对象——继承 class RichMan(object): def __init__(self): self.money 1000000000 self.company "阿里巴巴" self.__secretary "小蜜" def speak(self): print(f"我对钱不感兴趣,我最后悔的事,就是创建了{self.company…

UE4 .ini文件使用

在需要给配置文件的类中加上config标签,当然变量也要加 在项目的Config下,新建一个Default类的UCLASS中config等于的名字,这里结合上面截图就是DefaultTest 在下面写入 [/Script/项目名/类名] 然后写变量以及对应的值即可

音视频技术开发周刊 | 323

每周一期,纵览音视频技术领域的干货。 新闻投稿:contributelivevideostack.com。 Meta牵头组建开源「AI复仇者联盟」,AMD等盟友800亿美元力战OpenAI英伟达 超过50家科技大厂名校和机构,共同成立了全新的人工智能联盟。以开源为旗号…

QT用户管理效果预览

用户管理效果 QT 用户管理 GITHUB网站 QT版本 CMakeList.txt find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Sql REQUIRED) target_link_libraries(tableView PRIVATE Qt${QT_VERSION_MAJOR}::Widgets Qt${QT_VERSION_MAJOR}::Sql)GitHub代码获取链接 GitHub代码获取链接

AV1编码器的优化策略和实践技巧

目录 学习目标: 学习内容: 学习时间: 学习产出: 理解AV1编码器的原理和算法,掌握其核心优化思路和方法: 掌握AV1编码器的性能评估方法,了解如何测试和优化AV1编码器的性能: 学习AV1编…

16.(vue3.x+vite)组件间通信方式之具名插槽

前端技术社区总目录(订阅之前请先查看该博客) 示例效果 具名插槽 很多时候我们子组件中都不止只有一个 slot,比如弹窗组件,我们可能允许调用者同时传入 header、content、footer 等,这时就需要具名插槽 父组件代码 <template><div><div>父组件--Hel…

租一台服务器多少钱决定服务器的价格因素有哪些

租一台服务器多少钱决定服务器的价格因素有哪些 大家好我是艾西&#xff0c;服务器这个名词对于不从业网络行业的人们看说肯定还是比较陌生的。在21世纪这个时代发展迅速的年代服务器在现实生活中是不可缺少的一环&#xff0c;平时大家上网浏览自己想要查询的信息等都是需要服…

lowdb轻量数据库使用技巧

lowdb 是一个简单易用的本地 JSON 数据库&#xff0c;使用原生 JavaScript API 进行查询。在几个项目应用过&#xff0c;记录下常用的API和使用技巧。 使用的lowdb版本&#xff1a;"^1.0.0" 一、安装和用法 pnpm add lowdb1.0.0基本用法&#xff1a; const low re…