MySql数据库性能优化

1:尽量将or转换为union all

不适用索引:

SELECT * FROM user WHERE name='a'  OR age=20;

使用索引:

SELECT * FROM user WHERE name='a' UNION ALL SELECT * FROM user WHERE age=20;

2:SQL语句中IN包含的值不宜过多

MySQL对于IN做了相应的优化,即将IN中的常量全部存储在一个数组里面,而且这个数组是排好序的。但是如果数值较多,产生的消耗也是比较大的。再例如:select id from t where num in(1,2,3) 对于连续的数值,能用between就不要用in了;再或者使用连接来替换。

3:SELECT语句务必指明字段名称

SELECT*增加很多不必要的消耗(CPU、IO、内存、网络带宽);增加了使用覆盖索引的可能性;当表结构发生改变时,前断也需要更新。所以要求直接在select后面接上字段名。

4:当只需要一条数据的时候,使用limit 1

SELECT * FROM  user LIMIT 1;(这是为了使EXPLAIN中type列达到const类型)

5:如果排序字段没有用到索引,就尽量少排序

6:尽量避免使用IS NULL或IS NOT NULL

不使用索引:

SELECT * FROM user WHERE userId IS NOT NULL;

使用索引:

SELECT * FROM user WHERE userId>0;

7:使用合理的分页方式以提高分页的效

SELECT id,name FROM user limit 1001, 20

使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。

优化方法如下:可以取前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。比如此列中,上一页最大的id是866612。SQL可以采用如下的写法:

SELECT id,name FROM user WHERE id>1000 limit 20

由于本人新手,水平有限,若文章和代码有不妥之处,还请不吝赐教。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值