Mysql、Oracle、PostgreSql数据库索引失效场景详细讲解

Mysql、Oracle、PostgreSql数据库索引失效场景详细讲解

前言

Mysql、Oracle、PostgreSql数据库索引失效场景详细讲解。废话不多说直接贴:

1、任何计算、函数、类型转换
2!=<>
3、IS NULL或者IS NOT NULL。类似导致索引失效的还有NOT IN,NOT LIKE等,但是NOT EXISTS不会导致索引失效。
4、模糊查询通配符在开头
5、索引字段在表中占比较高
6、多字段btree索引查询条件不包含第一列
7、在WHERE中使用OR时,有一个列没有索引,那么其它列的索引将不起作用
8、多字段索引查询条件使用OR
在索引列上进行大于大于这类的比较后,这个列的索引是有效的,但是其后的索引将失效
9、覆盖索引不写*
尽量使用覆盖索引,而不要用select *。示例中,如果我们业务上只需要使用username、age、gender这三个字段,那么我们就使用
select username, age, gender,而不要用select *。这是因为这三个字段在索引中就已经维护了它们的值,定位索引后,就能检索出
它们的值。如果使用select *的话,定位到索引后,由于索引没有维护city的值,所以其后还会去检索city的值,造成了时间开销.
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值