0

0

小贝_mysql索引学习与优化_MySQL

php中文网

php中文网

发布时间:2016-06-01 12:59:03

|

1091人浏览过

|

来源于php中文网

原创

mysql索引与优化

简要:

一、索引是什么

二、索引类型及使用语法

三、全文索引说明

一、索引是什么

1、以书的目录为例,通过查看目录,再找到对应的内容。因此,索引就是给数据加上了’目录’,便于快速找到数据

2、索引的作用:

好处: 加快了查询速度

坏处: a、降低了增删改的速度

b、增大了表的文件大小(索引文件甚至可能比数据文件还大)

案例: 设有某个表15列,存在10列上有索引,共500w行数据,如何快速导入?

答: 1、把空表的索引全部删除 2、导入数据 3、数据导入完毕后再建立索引

3、索引算法

设有N条随机记录,不用索引,平均查找N/2次,用了索引呢?

3.1、二叉树索引对应次数为log2N次

说明例子,数据1,2,3,4,5,6,7,以中间值4为分界点

4

2 6

1 3 5 7

查找3需要多少次?

由于32,因此在以2为根节点的右边。结果需要2次

3.2、哈希索引,理论上为1次

说明例子,数据1,2,3,4,5,6,7

hash[1]=001

hash[2]=003

hash[3]=005

hash[4]=007

hash[5]=009

hash[6]=011

hash[7]=013

查找3需要多少次?

先hash下,得到005,这样就找到了。刚好1次。

hash的不足:

a、浪费空间,因为hash的值不连续。

b、hash要求高,确保每个值的hash值不同

4、索引的使用原则

a、不过度索引

b、索引条件列(where后面最频繁的条件比较适宜索引)

c、索引散列值,过于集中的值不要索引(如: 性别)

5、如何看表结构

5.1、存储引擎为myisam

\

frm为表结构、MYD为数据文件、MYI为索引文件

5.2、存储引擎为innodb

\

frm为表结构、ibd为数据文件和索引文件

 

二、索引类型及使用语法

1、类型

a、普通索引(index): 仅仅是加快查询速度

b、唯一索引(unique index): 行上的值不能重复

c、主键索引(primary key): 不能重复

d、全文索引(fulltext index):

唯一索引和主键索引的关系:

主键必唯一,但是唯一索引不一定是主键;一张表上只能有一个主键,但是可以有一个或多个唯一索引

2、如何查看表中的索引

\

3、建立索引

魔珐星云
魔珐星云

无需昂贵GPU,一键解锁超写实/二次元等多风格3D数字人,跨端适配千万级并发的具身智能平台。

下载

3.1、对已经存在的表建立索引

语法: alter table 表名 add index/uniqueindex/fulltext index/primary key [索引名](列名) (备注:索引名可选,不指定则与列名相同)

表结构:

create table m( id int, emailvarchar(30),tel char(11), intro text)engine=myisam charset=utf8;

\

 

a、给tel列建立普通索引

 

\

(备注: 指定索引名与列名相同)

 

\

b、给email列加上唯一索引

\

 

c、给intro列加上全文索引

\

 

d、给id列加上主键索引

 

\

e、加上多列组合索引

\

 

(备注: 这个普通索引m作用在列email和tel列上)

\

 

错误点:

\

错误原因: 没有指定该索引应用在那个列上。

3.2、建立新表时,指定索引

create table m(id int primary keyauto_increment, email varchar(30), tel char(11), intro text, index(tel), uniqueindex(email), fulltext index(intro) )engine=myisam charset=utf8;

 

4、删除索引

4.1、删除普通索引/唯一索引/全文索引

\

 

4.2、删除主键索引

如果主键列本身就是自增的,则删除时会报错

\

 

这个情况,应该先修改列的自增属性。

\

 

三、全文索引

全文索引在mysql的默认情况下,对于中文意义不大

因为英文有空格,标点符号来拆成单词,进而对单词进行索引。

而对于中文,没有空格来隔开单词。mysql无法识别每个中文词。

用法: match(全文索引名) against(‘keyword’);

相关专题

更多
菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

397

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

118

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS3 教程
CSS3 教程

共18课时 | 4.8万人学习

550W粉丝大佬手把手从零学JavaScript
550W粉丝大佬手把手从零学JavaScript

共1课时 | 0.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号