mysql 慢sql优化记录

最近在分析一条SQL,这条SQL执行时间去到2秒以上。SQL如下:

sql 复制代码
select
        count(d.id)   
    from
        t_msg d   
    where
        d.userid='12456'   
        and d.isread=0     
        AND d.msgnumber<> 'NEW-JCPT003'

表上索引有 idx_userid(userid),这条SQL是一条比较标准的统计SQL,涉及字段也少。

虽然表数据有一百多万,但加了索引,explain一下只扫描记录5w多,按道理耗时很少。仔细分析是查询语句中用到了非索引字段,如果能把语句中涉及到的字段都加入索引,这样SQL在执行中可以减少回表时间,回表时间在SQL执行中占比挺大的。

马上修改索引 idx_userid(userid,isread,msgnumber),执行一下只耗时0.5秒了。这里isread和msgnumber两列的值属于枚举类型,加入索引在查询时效果没那么大,而且msgnumber这里是<>,用不上索引。会有人认为对这两个字段加索引没意义,但如果从减少回表的角度考虑,加索引意义很大

后面又碰到一条类似的SQL

sql 复制代码
select
        count(*) as "ALL",
        sum(CASE 
            WHEN d.code='A' THEN 1 
            ELSE 0 
        END) AS "A",
        sum(CASE 
            WHEN d.code='B' THEN 1 
            ELSE 0 
        END) AS "B",
        sum(CASE 
            WHEN d.code='C' THEN 1 
            ELSE 0 
        END) AS "C",
        sum(CASE 
            WHEN d.code='D' THEN 1 
            ELSE 0 
        END) AS "D",
        sum(CASE 
            WHEN d.code='E' THEN 1 
            ELSE 0 
        END) AS "E",
        sum(CASE 
            WHEN d.code='F' THEN 1 
            ELSE 0 
        END) AS "F",
        sum(CASE 
            WHEN d.code='G' THEN 1 
            ELSE 0 
        END) AS "G"  
    FROM
        t_msg d
    WHERE
        1=1        
        AND d.msgitemnumber <> 'NEW-JCPT003'                    
        and d.userid='123456' limit 1

二话不说直接修改索引idx_userid(userid,isread,msgnumber,code) ,耗时也降到0.5秒以下了

相关推荐
jiayou641 小时前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北2 小时前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤21 小时前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12022 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip