尽量避免在where子句中做如下操作
-
使用or来连接条件,代替用union all
-
对查询进行优化,应尽量避免全表扫描,首先应考虑where和order by涉及的列上建立索引。
-
尽量避免在where子句中使用!=或<>操作符,否则将导致引擎放弃使用索引而进行全表扫描。
-
尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描。
-
如:select id from t where num is null
可以在null上设置默认值0,确保表中num列没有null值,然后可以如下查询
select id from t where num=0
-
like ‘%abc%’,若要提高效率,可以用全文检索
-
in和not in 也有慎用,对于连续的数值,可以between代替in,用exists代替in
-
避免对字段进行表达式操作,where num/2 = 100 代替为 where num = 200
-
避免对字段进行函数操作, where substring(name, 1,3)='abc' 代替为 where name like ‘abc%’
-
不要在where子句中的“=”左边进行函数、算数运输或其他表达式运输
-
若索引使复核索引,必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,并且尽可能让字段顺序与索引顺序相一致。