当前位置: 首页 > news >正文

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

http://www.lryc.cn/news/437830.html

相关文章:

  • SpringBoot常见面试题
  • springboot优雅停机无法关闭进程,kill无法停止springboot必须kill -9,springboot线程池使用
  • 【系统架构设计师-2015年真题】案例分析-答案及详解
  • MongoDB设置系统服务启动教程
  • mysql学习教程,从入门到精通,MySQL WHERE 子句(10)
  • 设计模式】Listener模式和Visitor模式的区别
  • 基于事件序列的数据获取
  • 太速科技-基于XC7Z100+AD9361的双收双发无线电射频板卡
  • 探索UWB技术的独特优势:实现高精度定位
  • 软件安装攻略:Sublime Text 下载安装和使用教程
  • ip地址为什么要轮换
  • C++ 继承【一篇让你学会继承】
  • DeviceNet网关HT3S-DNS-MDN读取七星华创CS310空气流量计数据应用案例
  • Smartbi体验中心新增系列Demo,用户体验更丰富
  • Kubernetes 与 springboot集成
  • 以太网传输出现不分包
  • [实践应用] 深度学习之激活函数
  • Java基础之数组
  • 基于SpringBoot+Vue的智慧自习室预约管理系统
  • pptpd配置文件/etc/pptpd.conf详解
  • springboot对数据库进行备份+对一个文件夹内的文件按时间排序,只保留最近的8个文件
  • 【软考中级攻略站】-软件设计师(4)-计算机网络基础
  • Android以及IoT设备传感器软件开发总结
  • Vue2/Vue3中编程式路由导航实践总结
  • 【nginx】ngx_http_proxy_connect_module 正向代理
  • 单考一个OCP认证?还是OCP和OCM认证都要考?
  • 在Spring官网查看Springboot与Java的版本对应关系
  • HarmonyOS学习(十二)——数据管理(一)分布式数据
  • 3D GS 测试自己的数据
  • 攻防世界 supersqli