基本写法优化

  1. 少使用select *,尽量使用具体字段
  2. 对于条件来说等号之类两边的字段类型要一致,字符串不加单引号索引会失效
  3. 尽量少使用Order By排序,对于需要多个字段进行排序的可以使用组合索引
  4. 对于group by语句要先过滤后分组
  5. 在查询时减少使用null,对字段有多个null的可以加默认值
  6. 少使用like,对于需要使用的,如需要使用尽量用like abc%这种,不要把%放字段前
  7. 在where后面少使用函数或者算数运算;
  8. 去除的distinct过滤字段要少,避免distinct * ;
  9. 不要超过5个以上的表连接。

    建立合适索引

  10. 对于高频筛选字段可以适当的建立索引;

  11. 一个表的索引最好不要超过5个,多了会影响插入修改;
  12. 不要对值是有限重复的字段建立索引,如性别等;
  13. 使用组合索引一定要遵守最左原则;

替代优化

  1. 不要使用not in和<> ,这个会破坏索引,not in可以用not exists来代替,<> 可以分成两个条件>或者<等
  2. 使用连接(join) 来代替子查询