原创 | SQL优化之索引的那些事儿

简介: 提到索引,想必小伙伴们都知道,它是为了提高查询效率而生。但是在查询过程中,怎么才能让我们的查询语句使用索引?相必大家或多或少都会遇到这样的问题。今天我们就来回答这个问题。

1. 聚集索引和非聚集索引


索引一般分为聚集索引和非聚集索引。

聚集索引速度很快,但只能建一个,所以尽量把经常使用的列建成聚集索引。

非聚集索引虽然没聚集索引快,但是可以建多个,比全表扫描快。



2

如何建立高效的索引


A.关联条件上建立索引

例如:SELECT  * FROM  T1JOIN  T2 ON  T1.ORDER_ID=T2.ORDER_ID;在关联条件ON后面的两个列就可以分别建立索引,这样会很快将符合关联条件的数据查询出来。B.在条件查询上建立索引例如:SELECT * FROM T1 WHERE  T1.PRICE>20;在WHERE条件PRICE列上就可以建立索引。注意:以下几种情况不会使用索引

  • 在索引列上使用了运算符的,例如:T1.PRICE*0.5>20,这种不会使用索引
  • 在索引列上使用了函数的,例如:UPPER(T1.ADDRESS)='NEWYORK',也不会使用索引
  • 在使用索引时存在空值NULL的,例如:T1.ADDRESS IS NULL,那么在查询时就不会走索引了
  • 字符型数据不加引号也不会使用索引例如:ORDER_ID原本是字符型,T1.ORDER_ID='112'会使用索引,但是如果去掉引号,变成了T1.ORDER_ID=112,查询语句不会报错,但是不会使用索引了。
  • 或(OR)和不等(<>,!=)以及NOT IN等这些也不会使用索引
  • 经常使用的LIKE,除了前置匹配,其他匹配均不走索引例如:T1.ADDRESS LIKE ‘NEW%’,这个走索引,但是像T1.ADDRESS LIKE ‘%NEW%’和T1.ADDRESS LIKE ‘%NEW’则均不走索引了
  • 最后如果查询优化器判断全表扫描比走索引还快也不会使用到索引。

C.建立索引的原则

  • 不频繁写入和更新的列适合建立索引
  • 经常查询的列适合建立索引
  • 重复数据较少的可以建立索引

D.联合索引的妙用联合索引就是几个列合在一起组成一个索引,这种在WHERE条件中相比单列索引会起到意想不到效果。例如:SELECT * FROM T1 WHERE T1.CITY=‘北京’ AND T1.DISTR='海淀区';这个时候将列CITY和DISTR建立成一个联合索引,效果会更好。注意:联合索引需要按顺序走,如果中间某个索引不能使用,那它之后的列均不会使用索引。例如:SELECT * FROM T1 WHERE T1.CITY=‘北京’AND LEFT(T1.DISTR,3)='海淀区' AND T1.ROAD='#10'如果我们将CITY,DISTR,ROAD建立成为联合索引,由于索引的前置规则,只会让CITY走索引,后面的DISTR因为使用了函数,索引失效,最后的ROAD列因为DISTR的失效也会跟着失效,这里记住即可。



3

什么情况不适合建立索引


由于创建索引和维护索引耗时,时间随着数据的增加而增加,成正比;需要占物理空间;当对表中的数据进行维护时,对索引也要进行维护,这样就降低了数据的维护速度。基于这些缺点,以下情况不适合建立索引

  • 对于在查询过程中很少使用或参考的列,不应该创建索引。
  • 对于那些只有很少数据值的列,不应该创建索引,例如:性别。
  • 对于那些定义为image,text和bit数据类型的列,不应该创建索引。
  • 当修改性能远大于检索性能,不应该建立索引。
  • 重复值较多的也不适合建立索引。


相关文章
|
2天前
|
SQL 资源调度 分布式计算
如何让SQL跑快一点?(优化指南)
这篇文章主要探讨了如何在阿里云MaxCompute(原ODPS)平台上对SQL任务进行优化,特别是针对大数据处理和分析场景下的性能优化。
|
5天前
|
SQL Oracle 关系型数据库
SQL优化-使用联合索引和函数索引
在一次例行巡检中,发现一条使用 `to_char` 函数将日期转换为字符串的 SQL 语句 CPU 利用率很高。为了优化该语句,首先分析了 where 条件中各列的选择性,并创建了不同类型的索引,包括普通索引、函数索引和虚拟列索引。通过对比不同索引的执行计划,最终确定了使用复合索引(包含函数表达式)能够显著降低查询成本,提高执行效率。
|
11天前
|
SQL 关系型数据库 MySQL
如何确认SQL用了索引:详细技巧与方法
在数据库管理中,索引是提高SQL查询性能的重要手段
|
11天前
|
SQL 监控 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
14天前
|
SQL 关系型数据库 PostgreSQL
遇到SQL 子查询性能很差?其实可以这样优化
遇到SQL 子查询性能很差?其实可以这样优化
51 2
|
10天前
|
SQL 存储 关系型数据库
SQL默认索引是什么:深入解析与技巧
在SQL数据库中,索引是一种用于提高查询性能的重要数据结构
|
11天前
|
SQL 存储 关系型数据库
SQL默认索引是什么
在SQL数据库中,索引是一种用于提高查询性能的数据结构
|
11天前
|
SQL 关系型数据库 MySQL
如何确认SQL用了索引
在数据库管理和优化过程中,确认SQL查询是否使用了索引是一个至关重要的步骤
|
11天前
|
SQL 存储 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
14天前
|
SQL 数据处理 数据库
SQL语句优化与查询结果优化:提升数据库性能的实战技巧
在数据库管理和应用中,SQL语句的编写和查询结果的优化是提升数据库性能的关键环节