MySQL高效查询

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值