博客
关于我
2020-06-05:索引不适用的条件
阅读量:298 次
发布时间:2019-03-01

本文共 771 字,大约阅读时间需要 2 分钟。

在数据库查询优化中,关于索引的使用仍然是一个值得深入探讨的话题。以下是一些需要注意的事项和优化建议。

首先,在索引列上使用函数会导致索引失效,这种情况需要特别注意。其次,最左前缀法则虽然在某些情况下非常有用,但并不是万能的。在处理索引列时,避免在索引列上执行不等式操作,这样可以有效减少索引失效的概率。对于Null和Not Null类型的字段,查询时需要特别注意,避免因为字段为Null而导致无法利用索引的情况。Like查询时,尽量避免在索引列上使用,否则会产生全表扫描的结果。

在实际应用中,索引的使用需要谨慎考虑以下因素:如果某个字段的唯一性极差,即使这个字段经常作为查询条件也不适合单独创建索引。对于频繁更新的字段,索引的效率会显著降低,因此不建议为这些字段创建索引。另外,如果某个字段在WHERE子句中很少被使用,给它创建索引也没有太大意义。最后,对于记录数量极少的表,索引的作用也会大打折扣。

关于SQL优化,福哥提出的"尽最不范覆 不囊来字哦"这几句话非常值得借鉴。具体来说,它强调了以下几点:尽量使用全值匹配的方式进行查询,遵循最佳左前缀法则。在使用索引时,避免在索引列上执行范围查询或不等式操作。对于覆盖索引的使用,要尽量多地进行,减少对索引的其他操作。对于不等式查询,除非非常必要,否则尽量避免使用。Null和Not Null类型的字段对查询性能有较大的影响,查询时要特别注意。Like查询时,尽量避免在索引列上使用,以免引发全表扫描。Character类型的字段在查询时需要用引号包裹,OR和UNION操作对于性能提升要比单独的OR语句更有效。

总的来说,数据库查询优化需要综合考虑多个因素,既要充分利用索引带来的查询性能优势,又要避免因为索引的使用而导致的额外负担。只有将这些因素结合起来,才能真正实现高效的数据库查询。

转载地址:http://pmmo.baihongyu.com/

你可能感兴趣的文章
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
查看>>
Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
查看>>
Netty:原理架构解析
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
Network 灰鸽宝典【目录】
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
network小学习
查看>>
Netwox网络工具使用详解
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
Net操作配置文件(Web.config|App.config)通用类
查看>>
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
New Relic——手机应用app开发达人的福利立即就到啦!
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>