前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >mysql创建索引

mysql创建索引

作者头像
周小董
发布2019-08-18 12:10:12
3.7K0
发布2019-08-18 12:10:12
举报

1、索引需要占用磁盘空间,因此在创建索引时要考虑到磁盘空间是否足够 2、创建索引时需要对表加锁,因此实际操作中需要在业务空闲期间进行

SELECT * FROM table_name WHERE column_1 LIKE '_好_'
 
如果要表示在字符串中既有A又有B,那么查询语句为:
SELECT * FROM table_name WHERE column_1 LIKE '%A%' AND column_1 LIKE '%B%';
 
SELECT * FROM table_name WHERE column_1 LIKE '[张李王]三';  //表示column_1中有匹配张三、李三、王三的都可以
SELECT * FROM table_name WHERE column_1 LIKE '[^张李王]三';  //表示column_1中有匹配除了张三、李三、王三的其他三都可以
 
//在模糊查询中,%表示任意0个或多个字符;_表示任意单个字符(有且仅有),通常用来限制字符串长度;[]表示其中的某一个字符;[^]表示除了其中的字符的所有字符
 
或者在全文索引中模糊查询
SELECT * FROM table_name WHERE MATCH(content) AGAINST('word1','word2',...);

索引分三种,普通索引,唯一索引,全文索引

image.png
image.png

索引方法,Hash 索引仅仅能满足"=",“IN"和”<=>"查询,不能使用范围查询 B-Tree最为频繁的索引类型

image.png
image.png

在已存在的表中,可以使用ALTER TABLE语句或者CREATE INDEX语句创建索引

在已存在的表中,索引的创建语句结构

  • 1.普通索引(Normal):
ALTER TABLE 表名 ADD INDEX 索引名(列名);
或
CREATE INDEX 索引名 ON 表名(列名);
  • 2.唯一索引(Unique):
ALTER TABLE 表名 ADD UNIQUE INDEX 索引名(列名);
或
CREATE UNIQUE INDEX 索引名 ON 表名(列名);

唯一索引的特点: 一个表中,可以有多个唯一索引 查询效率高 如果在某一列建立唯一索引,必须保证这列不能有重复数据 如果一个唯一索引上指定not null,等价于主键索引

  • 3.单列索引:
ALTER TABLE 表名 ADD INDEX 索引名(列名);
或
CREATE INDEX 索引名 ON 表名(列名);
  • 4.组合索引:
ALTER TABLE 表名 ADD INDEX 索引名(列名,列名2);
或
CREATE INDEX 索引名 ON 表名(列名1,列名2);

组合索引:用多个列组合构建的索引,这多个列中的值不允许有空值

ALTER TABLE 'table_name' ADD INDEX index_name('col1','col2','col3');

遵循**“最左前缀”**原则,把最常用作为检索或排序的列放在最左,依次递减,组合索引相当于建立了col1,col1col2,col1col2col3三个索引,而col2或者col3是不能使用索引的。

在使用组合索引的时候可能因为列名长度过长而导致索引的key太大,导致效率降低,在允许的情况下,可以只取col1和col2的前几个字符作为索引

ALTER TABLE 'table_name' ADD INDEX index_name(col1(4),col2(3));

表示使用col1的前4个字符和col2的前3个字符作为索引

  • 5.全文索引(Full Text):
ALTER TABLE 表名 ADD FULLTEXT INDEX 索引名(列名);
或
CREATE FULLTEXT INDEX 索引号 ON 表名(列名);
  • 6.空间索引:
ALTER TABLE 表名 ADD SPATIAL INDEX 索引名(列名);
或
CREATE SPATIAL INDEX 索引号 ON 表名(列名);
  • 7.主键索引:即主索引,根据主键pk_clolum(length)建立索引,不允许重复,不允许空值;
ALTER TABLE 'table_name' ADD PRIMARY KEY pk_index('col');

从命令上可以看出

索引按类别分类:普通索引,唯一索引,全文索引,空间索引 索引按列的数量分类:单列索引,多列索引。

试一下添加索引

1.首先搞个测试数据表

测试数据
测试数据

2.执行以下语句给这个数据表加上索引

ALTER TABLE test_7 ADD INDEX tidx_1(col2);

语句运行结果
语句运行结果

3.看看新增结果

image
image

可见该数据表已经多了一个tidx_1的索引

是不是很简单,当然可视化数据库管理软件可以更方便的管理索引,但是本文主要给大家讲解的是添加索引代码原理。大家可以尝试自己添加一下

删除索引语句结构

删除索引的语句方式主要有以下两种

删除主键索引
alter table 表名 drop primary;

其他索引的删除
ALTER TABLE 表名 DROP INDEX 索引名;
索引名就是`show keys from 表名` 中的 Key_name 字段

或
DROP INDEX 索引名 ON 表名

试一试删除索引

使用ALTER TABLE删除索引

ALTER TABLE test_7 DROP INDEX tidx_1;

运行结果
运行结果

如果所示删除成功,是不是很简单。

查看表中的索引

show keys from 表名;
show index from 表名;
desc 表名;

查看查询语句使用索引的情况

//explain 加查询语句
explain SELECT * FROM table_name WHERE column_1='123';

索引的优缺点

  • 优势:可以快速检索,减少I/O次数,加快检索速度;根据索引分组和排序,可以加快分组和排序;
  • 劣势:索引本身也是表,因此会占用存储空间,一般来说,索引表占用的空间的数据表的1.5倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,添加,修改)的效率,因为在修改数据表的同时还需要修改索引表;

参考:https://jingyan.baidu.com/album/27fa7326b574e746f8271fb3.html?picindex=5 https://baijiahao.baidu.com/s?id=1622429059628634435&wfr=spider&for=pc https://blog.csdn.net/tongdanping/article/details/79878302 https://blog.csdn.net/sophie1314/article/details/84073465 https://www.cnblogs.com/sweet521/p/6203360.html

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019年08月11日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 试一下添加索引
  • 删除索引语句结构
  • 查看表中的索引
  • 查看查询语句使用索引的情况
  • 索引的优缺点
相关产品与服务
数据库智能管家 DBbrain
数据库智能管家(TencentDB for DBbrain,DBbrain)是腾讯云推出的一款为用户提供数据库性能、安全、管理等功能的数据库自治云服务。DBbrain 利用机器学习、大数据手段、专家经验引擎快速复制资深数据库管理员的成熟经验,将大量传统人工的数据库运维工作智能化,服务于云上和云下企业,有效保障数据库服务的安全、稳定及高效运行。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档