mysql select count(*) 优化

最近一直在做微服务的压测和改善,从代码层面,逻辑层面,结合业务进行了调整,下面是关于sql层面的优化点:

一般我们判断记录是否存在,都会在mapper.xml中写如下的sql

select  count(*) from xxx_0000 where is_deleted='N';

使用datagrip执行上面的sql,在控制台可以看到如下输出:
在这里插入图片描述
返回一条记录,耗时1s 690ms

下面是对这条sql进行优化的改写:

select count(*) from xxx_0000 where is_deleted='N' limit 1;

同样使用datagrip执行上述的sql,可以在控制台看到如下的输出:

在这里插入图片描述
相同的表和where条件,后者只是加了limit 1,效率提升了不少。

当然是否采用加limit 1的限制条件,是需要结合业务需求的,如果你count只是为了判断是否存在记录,那么加上limit 1,响应时间肯定会有提高,但是如果你count是为了得到该符合查询条件的个数,那么可能加limit 1的结果并不是你想要的。

总结:对于sql的优化,不单单是加索引之类,还需要结合业务需求去优化sql的逻辑和索引字段等。

mysql select count(*) 优化_第1张图片

你可能感兴趣的:(MySQL总结归纳,mysql)