sql中索引查看是否生效

打印 上一主题 下一主题

主题 521|帖子 521|积分 1563

在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 进行解释,偶然间可能因为数据量问题不走索引,固然还会有其他原因

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

伤心客

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表