SQL中的联合索引和普通索引问题

 更新时间:2023年09月05日 14:37:35   作者:Annie_Mint  
这篇文章主要介绍了SQL中的联合索引和普通索引问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

SQL中联合索引和普通索引

解释

1、索引:是数据库管理系统中一个排序的数据结构,并用以协助快速查询、更新数据库表中数据。

2、联合索引:就是创建一个索引,索引中包含多个列。

3、普通索引:即单个索引,一个索引包含一个列。

区别

联合索引中列的顺序非常重要,从左原则。a,ab,ba,abc。

单个索引:一个一个起作用,也就是说有三个单个索引,哪个条件查询在前哪个起作用,其他不起作用。

结论

一般来说,列表搜索需要多个列查询,此时就可以使用联合索引,都是and的关系。

什么时候需要创建索引:

1、where条件会经常出现的,并且当前表的数量比较大。

2、where条件中是用and而非or的时候。

3、联合索引比单个索引更适合,因为索引占用一定磁盘空间,也就说明有一定的开销,如果多个单个索引比较多,那么多资源的浪费也比较多,联合索引相当于对多个列建索引,并且只建一次,and条件下非常适合。

普通索引跟联合索引哪个更好

索引描述

普通索引是在单个列上创建的索引,它可以加速针对该列的查询,例如使用 WHERE 子句、ORDER BY 子句和 GROUP BY 子句进行过滤、排序和分组。普通索引的优点是简单、易于维护,适用于单个列的查询场景。

联合索引是在多个列上创建的索引,它可以加速多个列的组合查询,例如使用多个 WHERE 子句和 ORDER BY 子句进行过滤和排序。联合索引的优点是可以通过一个索引满足多个列的查询需求,从而减少磁盘 I/O 和索引维护的开销,适用于多列组合查询的场景。

使用建议

如果查询只涉及单个列,并且该列的基数(不同值的数量)很大,则使用普通索引效果更好。

如果查询涉及多个列,并且这些列经常一起查询,或者查询条件在这些列之间频繁变化,则使用联合索引效果更好。

如果查询涉及多个列,但是这些列的基数很小,例如只有两个取值,那么使用联合索引的效果可能不如单独为每个列创建索引的效果。

心得

普通索引和联合索引各有优缺点,具体使用哪种索引取决于查询的场景。

需要注意的是,使用索引并不总是能提高查询性能,有时候索引反而会降低查询性能。

因此,在创建索引时,需要根据具体的查询场景和数据分布情况进行综合考虑,权衡索引的优缺点,选择最适合的索引类型和索引列。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于MYSQL 远程登录的授权方法 命令

    关于MYSQL 远程登录的授权方法 命令

    默认是不允许远程连接的,因为有很大的安全隐患。需要手动增加可以远程访问数据库的用户
    2011-11-11
  • 详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑

    详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑

    datetime和timestamp这两种类型都是用于表示年月日时分秒格式的数据,那么他们有那么区别,本文就详细的介绍一下MySQL timestamp和datetime坑,文中通过示例代码介绍的非常详细,感兴趣的小伙伴们可以参考一下
    2021-12-12
  • MySQL字段长度与索引限制问题的原因分析及解决方案

    MySQL字段长度与索引限制问题的原因分析及解决方案

    在数据库开发与维护过程中,字段长度和索引限制是常见的性能与稳定性问题,本文将通过一个实际案例,详细分析 “Data too long for column” 和 “Specified key was too long” 错误的原因,并提供多种解决方案,帮助开发者优化数据库设计,需要的朋友可以参考下
    2025-07-07
  • MySQL查看版本的五种方法总结

    MySQL查看版本的五种方法总结

    在日常项目开发过程中,我们经常要连接自己的数据库,此时不知道数据库的版本是万万不可的,下面这篇文章主要给大家介绍了关于MySQL查看版本的五种方法,需要的朋友可以参考下
    2023-02-02
  • MySQL 13表数据删掉一半表文件大小不变的原因分析

    MySQL 13表数据删掉一半表文件大小不变的原因分析

    这篇文章主要介绍了MySQL 13表数据删掉一半表文件大小不变的原因分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2025-07-07
  • Windows下MySQL服务无法停止和删除的解决办法

    Windows下MySQL服务无法停止和删除的解决办法

    我在 Windows 操作系统上,使用解压压缩包的方式安装 MySQL。遇到一点问题,下面通过本文给大家分享Windows下MySQL服务无法停止和删除的解决办法,需要的朋友可以参考下
    2017-02-02
  • MySQL实现字符串的拼接,截取,替换,查找位置的操作

    MySQL实现字符串的拼接,截取,替换,查找位置的操作

    这篇文章主要介绍了MySQL实现字符串的拼接,截取,替换,查找位置的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-02-02
  • MySQL中row_number的实现过程

    MySQL中row_number的实现过程

    这篇文章主要介绍了MySQL中row_number的实现过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • MySQL 机器重启后gtid_executed初始化流程解析

    MySQL 机器重启后gtid_executed初始化流程解析

    文章介绍了MySQL中gtid_executed和gtid_purged的初始化过程,包括从mysql.gtid_executed表加载、扫描binlog文件以验证和补充、最终计算并合并这两个集合,以及gtid_purged的计算方法,感兴趣的朋友跟随小编一起看看吧
    2025-12-12
  • MySQL5.7安装过程并重置root密码的方法(shell 脚本)

    MySQL5.7安装过程并重置root密码的方法(shell 脚本)

    由于 MySQL 5.7 版本的 root 密码是首次启动时随机生成的,并且还要求必须修改后才能使用。下面小编给大家分享使用shell 脚本完成安装和设置新的 root 密码的方法,一起看看吧
    2016-12-12

最新评论