1、基本写法优化;
1、少使用select * ,尽量使用具体字段;
2、对于条件来说等号之类两边的字段类型要一致,字符串不加单引号索引会失效;
3、尽量少使用Order By 排序,对于需要多个字段进行排序的可以使用组合索引;
4、对于group by 语句要先过滤后分组;
5、在查询时减少使用null,对字段有多个null的可以加默认值;
6、少使用like,对于需要使用的, 如需要使用尽量用 like abc%这种,不要把%放字段前面;
7、在where后面少使用函数或者算数运算;
8、去除的distinct 过滤字段要少,避免 distinct * ;
9、不要超过5个以上的表连接。
2、建立使用合适索引;
1、对于高频筛选字段可以适当的建立索引;
2、一个表的索引最好不要超过5个,多了会影响插入修改;
3、不要对值是有限重复的字段建立索引,如性别等;
4、使用组合索引一定要遵守最左原则;
3、替代优化
1、不要使用not in 和<>,这个会破坏索引,not in 可以用not exists 来代替,<>可以分成两个条件 >或者<等;
2、使用连接(join)来代替子查询;
标签:不要,distinct,SQL,索引,使用,null,优化 From: https://www.cnblogs.com/csh-java/p/17139043.html