浅谈数据库索引的使用规则

对各位兄弟的建议:有些论坛或者帖子,若果感觉自己要掌握这些知识点,最好试试,不要随便转帖,让错误的东西误导更多的人!!!

浅谈数据库索引主要包括如下几个方面

  • 索引原则
  • 所谓的最左原则(重点)

 索引失效的条件

1、使用不等于操作符(<>, !=);

下面这种情况,即使在列dept_id有一个索引,查询语句仍然执行一次全表扫描
select * from dept where staff_num <> 1000;
但是开发中的确需要这样的查询,难道没有解决问题的办法了吗?
方法:select * from test_users where age>100 union all  select * from test_users where age<100

2、使用 LIKE ‘%T’ 进行模糊查询

3、不要在 where 子句中的“=”左边进行函数、算术运算或其他表达式运算

 select * from test where round(id)=10

4、比较不匹配数据类型

   dept_id是一个varchar2型的字段,在这个字段上有索引,但是下面的语句会执行全表扫描。select * from dept where dept_id = 900198;这是因为 oracle 会自动把 where 子句转换成 to_number(dept_id)=900198,相当于使用函数,这样就限制了索引的使用。

5、Mysql(btree) is null走索引,oracle  is  null 不走



6、B-tree索引 is null不会走,is not null会走,位图索引 is null,is not null 都会走(自己没有试验)

7、 创建复合索引,使用like 破坏复合索引,只有部分起作用;or会导致复合索引完全失效


oracle、mysql的最左原则:

1.联合索引:使用or导致联合索引失效;

 创建索引利用age 和address





2.最左原则:where 的执行是从右到左执行,使用联合索引,把过滤量大的条件放到左边

  mysql:复合索引,必须按照你创建的索引的顺序(必须含有最左列):




 oracle:

版本10:复合索引,必须按照你创建的索引的顺序(必须含有最左列)



版本11:复合索引,含有任何一个就可以




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值