MYSQL中优化SQL语句查询

尽量避免在where子句中做如下操作

  1. 使用or来连接条件,代替用union all

  2. 对查询进行优化,应尽量避免全表扫描,首先应考虑where和order by涉及的列上建立索引。

  3. 尽量避免在where子句中使用!=或<>操作符,否则将导致引擎放弃使用索引而进行全表扫描。

  4. 尽量避免在where子句中对字段进行null值判断,否则将导致引擎放弃使用索引而进行全表扫描。

  5. 如:select id from t where num is null

    可以在null上设置默认值0,确保表中num列没有null值,然后可以如下查询

    select id from t where num=0

  6. like ‘%abc%’,若要提高效率,可以用全文检索

  7. in和not in 也有慎用,对于连续的数值,可以between代替in,用exists代替in

  8. 避免对字段进行表达式操作,where num/2 = 100 代替为 where num = 200

  9. 避免对字段进行函数操作, where substring(name, 1,3)='abc' 代替为 where name like ‘abc%’

  10. 不要在where子句中的“=”左边进行函数、算数运输或其他表达式运输

  11. 若索引使复核索引,必须使用到该索引中的第一个字段作为条件时才能保证系统使用该索引,并且尽可能让字段顺序与索引顺序相一致。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值