mysql SQL优化

1.应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引
2.如下查询不走索引
1)where 子句中使用!=或<>操作符
2)where 子句中对字段进行 null 值判断
3) where 子句中使用 or 来连接条件
4)where like '%abc%'  ,可以考虑全文检索,like 'abc%'走索引
5)in 和 not in 也要慎用 ,能用 between 就不要用 in 
6)where 子句中使用参数
select id from t where num=@num 
可以改为强制查询使用索引: 
select id from t with(index(索引名)) where num=@num 
7)where 子句中对字段进行表达式操作,
where num/2=100 可以改为 where num=100*2 
8)where子句中对字段进行函数操作
9)尽量用 exists 代替 in 
3.当索引列有大量数据重复时,SQL查询可能不会去利用索引,如一表中有字段sex,male、female几乎各一半,那么即使在sex上建了索引也对查询效率起不了作用。
4.尽量使用数字型字段
5.尽可能的使用 varchar/nvarchar 代替 char/nchar 
6.用具体的字段列表代替“*”
7.使用表变量来代替临时表
8.尽量避免使用游标,因为游标的效率较差
9.count(1)和count(primary_key) 优于 count(*)
10.尽量用 union all 代替 union
11.尽量早过滤
12.where 子句避免类型转换
13.优先优化高并发的 SQL,而不是执行频率低某些“大”SQL
14.尽可能对每一条运行在数据库中的SQL进行 explain
15.MySQL只有对以下操作符才使用索引:<,<=,=,>,>=,BETWEEN,IN,以及某些时候的LIKE。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值