IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Mysql 索引原理/(图文) -> 正文阅读

[大数据]Mysql 索引原理/(图文)

没有一堆似是而非的类比,直白明了,一看就懂。

原文地址:????????http://gk.link/a/11bZx

图1. 主键索引(也叫聚簇索引)

1.叶子节点是数据页,存放完整的数据条目;非叶子节点是索引页,存放了"子索引页地址+稀疏主键"或者"数据页地址"。数据页和索引页都以文件形式存放在磁盘上。

2.上述根据主键维护一棵B+树,对应就形成了聚簇索引;如果根据非主键维护一棵B+树,就形成了非聚簇索引。(主键,“非主键的随机组合”)就形成了多个不同的非聚簇索引。非聚簇索引,不要求非主键键值的唯一性,因为已经主键绑定在一起,整体上能唯一确定一条数据。

3.值得说明的是,如果知道要查的数据的主键,总是可以优先使用主键索引,根本不需要使用非聚簇索引。然而细细想来,这是很难做到的。因为对于主键的要求是唯一性,不能有重复,对于海量的数据,不可能做到每个主键有实际意义而且又唯一。在必须满足唯一性的前提下,主键只能设计的很抽象,抽象的东西很难直观反映出我们要查的数据的特点,所以在查询之前我们是很难知道主键的。所以只使用主键索引,虽理论可行,但是实践完全没法实现。

????????uuid虽然可以做到唯一性,但是占用空间太大,影响存储效率,因为在索引页中也要存储主键(并且uuid对人不友好,肉眼看上去难区分大小)。所以主键一般选用自增id。

4. mysql 建表时默认没有生成索引,所以在查询时是遍历整张表的(全文查询),如果数据量变大,查询速度会越来越慢。

????????

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-26 11:37:32  更:2022-02-26 11:40:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 12:00:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码