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秒以下了

相关推荐
S1998_1997111609•X8 小时前
论当今社会主义与人文关怀人格思想下的恶意仿生注入污染蜜罐描述进行函数值非法侵入爬虫的咼忄乂癿〇仺⺋.
数据库·网络协议·百度·ssh·开闭原则
倔强的石头_9 小时前
kingbase备份与恢复实战(六)—— 备份自动化与保留策略:Windows任务计划+日志追溯
数据库
轻刀快马10 小时前
别被 ORM 框架宠坏了:从一场“订单消失”悬案,看懂 MySQL 为什么要强推 InnoDB
数据库·mysql
学网安的肆伍10 小时前
【043-WEB攻防篇】PHP应用&SQL注入&符号拼接&请求方法&HTTP头&JSON&编码类
sql·安全·php
后端漫漫12 小时前
Redis 客户端工具体系
数据库·redis·缓存
PaperData13 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF
数据库·人工智能·数据分析·经管
星河耀银海13 小时前
C语言与数据库交互:SQLite实战与数据持久化
c语言·数据库·sqlite·交互
过期动态14 小时前
MySQL中的约束
android·java·数据库·spring boot·mysql
程序员陆通14 小时前
月烧 400 刀到不到 20 刀:我是怎么把 OpenClaw 的 Token 账单砍掉 95% 的
java·前端·数据库
Shan120514 小时前
站在计算机领域视角看:SQL注入攻击
网络·数据库·sql