【Mysql索引】五种索引类型

一、前期准备

  1. 创建一个表,如果有测试的表也可以用(把主键id设置为自增)
  2. 如果给字段添加的值有中文,需要将字符集改为UTF-8的格式
  3. 保存存储过程,用来添加100w条数据(字段和数据可以自己修改)
    在这里插入图片描述
  4. 调用存储过程来添加100w条数据
    在这里插入图片描述
  5. 执行的过程中会比较慢,可以使用select语句,查看创建了多少条数据
    在这里插入图片描述

二、实操实战

1、主键索引 primary

mysql提前给我们创建好了,不需要我们自己创建主键索引。

2、唯一索引 unique

sql语句:SELECT * FROM test where user_name =‘姓名_1’
创建唯一索引:create unique index username ON test(user_name);

①、执行效果

1)、没创建唯一索引

在这里插入图片描述

2)、创建了唯一索引

在这里插入图片描述

3、普通索引 noraml

sql语句:SELECT * FROM test WHERE password=‘密码:55’
创建普通索引:create index password on test( password );

①、执行效果

1)、没有创建普通索引

在这里插入图片描述

2)、创建了普通索引

在这里插入图片描述

4、全文索引 fulltext

执行全文索引的SQL语句: SELECT * FROM test WHERE MATCH(text) AGAINST(‘账号1’ IN BOOLEAN MODE); match()函数中的值要和全文索引添加的列保持一致。 against()函数中的值要填写要搜索的关键字后面可以添加搜索的条件语句

①、执行效果

1)、没有添加索引

在这里插入图片描述

2)、添加索引

在这里插入图片描述

5、组合索引

示例:SELECT * FROM test where user_name=“姓名_10” AND password=“密码:10”
创建组合索引:create index (索引名)username、password on (表名)test ((添加索引的字段)user_name, password)

①、执行效果

1)、没有添加索引

在这里插入图片描述

2)、添加索引

在这里插入图片描述

三、索引的优势利弊

MySQL索引的优势:

  1. 提高查询效率:索引使得MySQL可以快速的查找到需要的数据,可以大大缩短查询的时间。

  2. 提高数据检索能力:通过在索引列上建立索引,可以让MySQL更有效率地检索数据,提高数据检索能力。

  3. 提高数据的唯一性:可以通过在列上建立唯一索引来保证数据的唯一性。

  4. 可以加速排序:索引可以加速MySQL对数据的排序操作,提高数据排序的效率。

MySQL索引的劣势:

  1. 增加了空间和时间的消耗:索引会占用额外的存储空间, 并且对于数据的插入、更新和删除操作也会增加时间消耗。

  2. 挑选合适的索引不容易:建立索引要根据实际情况进行选择,如果不选对了索引,反而会降低查询效率。

  3. 可能存在冗余索引:索引的建立并不一定能够提高查询效率,反而会造成冗余索引,浪费存储空间。

总之,MySQL索引可以提高查询效率和数据检索能力,加速排序,保证数据的唯一性,但是要合理地建立索引,以避免冗余索引。

四、索引的特点

MySQL索引具有以下特点:

  1. 提高查询效率:索引可以根据索引列快速定位到需要的数据行,大大提高了查询效率。

  2. 通过树结构实现:MySQL索引采用的是B-tree或者B+tree数据结构,这种树状结构可以快速找到索引列对应的数据。

  3. 会占用存储空间:索引会占用额外的存储空间,特别是在大量数据下,索引可能会占用很多空间。

  4. 对数据增删改操作有影响:索引会影响数据的插入、更新和删除操作的性能,因为这些操作会触发索引的更新。

  5. 可以提高排序效率:因为索引已经对数据进行了排序,所以对这些数据进行排序操作时,可以大大提高排序效率。

  6. 可以保证数据的唯一性:通过在列上建立唯一索引,可以保证列中的数据唯一。

  7. 可以根据需要建立不同类型的索引:MySQL可以根据需要建立不同类型的索引,如单列索引、组合索引、全文索引等。

总之,MySQL索引可以提高查询效率、保证数据唯一性、提高排序效率等,但也会占用存储空间、影响数据增删改操作等。因此,在使用索引时,需要谨慎地考虑,根据实际需要进行建立索引。

五、总结

MySQL的不同索引类型在不同的应用场景中有着各自的优缺点。选择适当的索引类型可以大大提高数据库的查询性能和效率。根据具体的业务需求,选择合适的索引类型来优化数据库是非常重要的一环。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃芋圆的兔子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值