1、 包含多个表的情况下,你必须选择记录条数最少的表作为基础表。如果有3个以上的表连接查询, 那就需要选择交叉表(intersection table)作为基础表, 交叉表是指那个被其他表所引用的表。
2、 根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉最大数量记录的条件必须写在WHERE子句的末尾
3、 会将‘*’依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间
4、 使用IN代替OR: IN执行的速度比OR快,or的效率是n级别,in的消息时log(n)级别 ,in的个数建议控制在200以内
5、 对于连续的值就不要用IN改用between 如下
低效SELECT id FROM kenny_1 WHERE id in(1,2,3)
可以改成
高效SELECT id FROM kenny_1 WHERE id BETWEEN 1 and 3
6、 尽量使用UNION ALL替代UNION : UNION ALL执行所需要的时间少,确定查询结果中不会有重复的或不需要去重的优先使用ALL
7、 批量INSERT插入多条转为一条(分批次):如下
低效INSERT INTO t (id, name) VALUES(2,'张三');
INSERT INTO t (id, name) VALUES(3,'李四');
可以写为
高效INSERT INTO t (id, name) VALUES(1,'张三'), (2,'李四')。
8、 禁止不必要的ORDER BY排序
9、 不使用子查询而使用关联查询
10、 LIKE双百分号无法使用到索引尽量使用单百分号
低效SELECT * FROM t WHERE name LIKE '%张%';
可以写为
高效SELECT * FROM t WHERE name LIKE '张%';
11、 避免数据类型不一致 下面的id 为int类型
低效 SELECT * FROM t WHERE id = ‘1’
高效 SELECT * FROM t WHERE id = 1
12、 避免在 where 子句中对字段进行 null 值判断因为null会导致引擎放弃的使用索引二进行全表查询,大多数时候应该使用NOT NULL 或者使用一个特殊的值,如0,-1作为默认值(在存储的时候)
13、 CAST((CAST(SYSDATE()AS DATE) - INTERVAL 1 DAY)AS DATETIME) 获取昨天的零点
14、 CAST(CAST(SYSDATE()AS DATE)AS DATETIME) 获取今天的零点
15、select count(*) into @v_notuse from ',custlists,' where flagclean>=2 将 count(*)
值附给v_notuse