惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

酷 壳 – CoolShell
酷 壳 – CoolShell
H
Hacker News: Front Page
P
Palo Alto Networks Blog
T
ThreatConnect
Apple Machine Learning Research
Apple Machine Learning Research
博客园_首页
T
True Tiger Recordings
P
Privacy & Cybersecurity Law Blog
B
Blog
IT之家
IT之家
Last Week in AI
Last Week in AI
F
Full Disclosure
Hacker News: Ask HN
Hacker News: Ask HN
C
Comments on: Blog
Microsoft Azure Blog
Microsoft Azure Blog
C
Cybersecurity and Infrastructure Security Agency CISA
Microsoft Security Blog
Microsoft Security Blog
博客园 - 【当耐特】
N
News and Events Feed by Topic
NISL@THU
NISL@THU
腾讯CDC
雷峰网
雷峰网
Security Latest
Security Latest
李成银的技术随笔
M
Microsoft Research Blog - Microsoft Research
L
LangChain Blog
L
Lohrmann on Cybersecurity
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
C
Check Point Blog
Y
Y Combinator Blog
Recent Announcements
Recent Announcements
博客园 - Franky
N
News | PayPal Newsroom
V
V2EX
A
About on SuperTechFans
The Register - Security
The Register - Security
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Google Online Security Blog
Google Online Security Blog
MyScale Blog
MyScale Blog
Cisco Talos Blog
Cisco Talos Blog
Vercel News
Vercel News
WordPress大学
WordPress大学
C
Cyber Attacks, Cyber Crime and Cyber Security
The Hacker News
The Hacker News
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
爱范儿
爱范儿
A
Arctic Wolf
L
LINUX DO - 最新话题
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More

博客园 - 甩掉裤衩凭风吹

Go学习例子(六) - 甩掉裤衩凭风吹 Go学习例子(五) - 甩掉裤衩凭风吹 Go学习例子(四) Go学习例子(三) Go学习例子(二) Go学习例子(一) 一、Python基础语法 - 甩掉裤衩凭风吹 Python爬虫实战一之爬取糗事百科段子 Python爬虫系列:五、正则表达式 Python爬虫系列:四、Cookie的使用 - 甩掉裤衩凭风吹 python爬虫系列:三、URLError异常处理 - 甩掉裤衩凭风吹 python系列:二、Urllib库的高级用法 - 甩掉裤衩凭风吹 python系列:一、Urllib库的基本使用 - 甩掉裤衩凭风吹 二十七、mysql如何确保数据不丢失?有几点值得我们借鉴 二十六、聊聊mysql如何实现分布式锁 - 甩掉裤衩凭风吹 二十五、sql中where条件在数据库中提取与应用浅析 二十四、如何正确的使用索引? 二十二、mysql索引原理详解 二十一、什么是索引?
二十三、mysql索引管理详解
甩掉裤衩凭风吹 · 2019-11-01 · via 博客园 - 甩掉裤衩凭风吹

一、索引分类

  分为聚集索引非聚集索引

  聚集索引

    每个表有且一定会有一个聚集索引,整个表的数据存储在聚集索引中,mysql索引是采用B+树结构保存在文件中,叶子节点存储主键的值以及对应记录的数据,非叶子节点不存储记录的数据,只存储主键的值。当表中未指定主键时,mysql内部会自动给每条记录添加一个隐藏的rowid字段(默认4个字节)作为主键,用rowid构建聚集索引。

    聚集索引在mysql中又叫主键索引

  非聚集索引(辅助索引)

    也是b+树结构,不过有一点和聚集索引不同,非聚集索引叶子节点存储字段(索引字段)的值以及对应记录主键的值,其他节点只存储字段的值(索引字段)。

    每个表可以有多个非聚集索引。

    mysql中非聚集索引分为
    单列索引

即一个索引只包含一个列。

    多列索引(又称复合索引)

即一个索引包含多个列。

    唯一索引

索引列的值必须唯一,允许有一个空值。

  数据检索的过程

    

     左边为innoDB(聚簇)表分布    

    上面的表中有2个索引:id作为主键索引,name作为辅助索引。

    innodb我们用的最多,我们只看图中左边的innodb中数据检索过程:

    如果需要查询id=14的数据,只需要在左边的主键索引中检索就可以了。

    如果需要搜索name='Ellison'的数据,需要2步:

    1. 先在辅助索引中检索到name='Ellison'的数据,获取id为14

    2. 再到主键索引中检索id为14的记录

    辅助索引相对于主键索引多了第二步。  

二、索引管理

  创建索引

    方式1:
    create [unique] index 索引名称 on 表名(列名[(length)]);
    方式2:
    alter 表名 add [unique] index 索引名称 on (列名[(length)]);

如果字段是char、varchar类型,length可以小于字段实际长度,如果是blog、text等长文本类型,必须指定length。

[unique]:中括号代表可以省略,如果加上了unique,表示创建唯一索引。

如果table后面只写一个字段,就是单列索引,如果写多个字段,就是复合索引,多个字段之间用逗号隔开。

  删除索引

    drop index 索引名称 on 表名;

  查看索引

查看某个表中所有的索引信息如下:

    show index from 表名;

  索引修改

    可以先删除索引,再重建索引。

三、示例  

  创建索引

    create index idx1 on test1 (id);

    create unique index idx2 on test1(name);  

  创建索引并指定长度

    select * from test1 a where a.email = 'javacode1000085@163.com';

    所有的email记录,每条记录的前面15个字符是不一样的,结尾是一样的(都是@163.com),通过前面15个字符就可以定位一个email了,那么我们可以对email创建索引的时候指定一个长度为15,这样相对于整个email字段更短一些,查询效果是一样的,这样一个页中可以存储更多的索引记录,命令如下:

    create index idx3 on test1 (email(15));  

  查看表中的索引

    show index from test1  

  删除索引

    我们删除idx1,然后再列出test1表所有索引,如下:

    drop index idx1 on test1;

    show index from test1;