sql中索引查看是否生效

在pg数据库中有多种索引存在,在一般情况下我们取使用普通索引

以下是一些常见导致索引未命中的原因和优化策略

1.如果查询中的条件与索引字段的顺序不匹配,或者索引字段没有完全包含在查询条件中,索引可能不会被使用。

2.在查询中使用函数操作(如 LOWER())会导致索引无法被利用,因为函数操作改变了列的值。

3.有时数据库优化器会认为全表扫描比使用索引扫描更快,尤其是当查询的数据量较大,或者返回的记录很多时。PostgreSQL 的优化器根据表的统计信息做出判断。

如果查询返回的行数较多(大于某个比例),优化器可能会选择全表扫描。你可以调整查询的过滤条件,使返回的行数更小,从而倾向于使用索引

4.查询中的列数据类型与索引中的数据类型不匹配,可能导致无法利用索引。例如,查询中使用 ::TEXT 强制转换数据类型,可能导致索引失效。

5.索引对高选择性的字段(即字段值不同种类很多)效果最好。如果你在低选择性的字段(例如布尔值字段)上创建索引,数据库可能认为索引扫描不如全表扫描高效。

6.如果查询中有子查询、嵌套查询、窗口函数等,数据库优化器可能难以找到最优的执行计划,导致索引失效。

create index idx_table_idxname on table(file1,file2)

创建完索引可以使用EXPLAIN ANALYZE查看自己的sql是否命中

create index idx_demand_domain on demand_mstr(lower(demand_domain_id))

eg:select * from demand_mstr where lower(demand_domain_id) = 'acs'select * from demand_mstr where lower(demand_domain_id) = 'acsd'

这两个语句一样的只是条件不一样,但是一个命中一个没有,就是因为数据库在选择时候,acs数据太多,认为全局扫描更快。

如果有时候命中不了索引,可以尝试加上limit1000 进行解释,有时候可能因为数据量问题不走索引,当然还会有其他原因

相关推荐
迷藏4943 分钟前
**TiDB 在高并发场景下的性能优化实战:从慢查询到极致吞吐的跃迁**在现代分布式系统中,数据库不仅是数据存储的
java·数据库·python·性能优化·tidb
m0_678485454 分钟前
如何自动同步SQL异构表数据_利用触发器实现实时数据复制
jvm·数据库·python
Shorasul12 分钟前
如何防御SQL注入的SQL畸形查询_利用语法分析器检测
jvm·数据库·python
黑牛儿21 分钟前
2026 慢 SQL 优化手册:EXPLAIN 深度解读 + 9 类索引失效场景(生产避坑)
数据库·sql
jgszhuzhu29 分钟前
mysql 独立用户
数据库·mysql
oradh31 分钟前
Oracle数据库完整性约束概述
数据库·oracle·数据库基础·数据库入门·oracle数据完整性·oracle数据库约束类型
AKA__Zas32 分钟前
视图与索引
数据库·学习方法
毅炼33 分钟前
MySQL 常见问题总结(1)
java·大数据·数据库
路由侠内网穿透35 分钟前
本地部署开源发票管理系统 Invoice Ninja 并实现外部访问
运维·服务器·数据库·物联网·开源
m0_6403093038 分钟前
c++如何判断两个文件路径是否物理指向同一个磁盘文件_equivalent【详解】
jvm·数据库·python