MySQL索引查询条件使用函数导致索引失效

 

索引失效

复制代码
EXPLAIN
SELECT
    dt.name AS deviceName,
    su.`name` AS userName,
    date_format(co.upload_time, '%Y%m%d') as time
FROM
    tb_cust_order co
INNER JOIN sys_user su ON co.work_id = su.id
INNER JOIN tb_device d ON d.id=JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]')
INNER JOIN tb_device_type dt ON dt.id=d.device_type_id
WHERE
    co.unit_id = 1498576617260576769
AND co.`status` = 'SUCCESS'
AND co.upload_time >= '2022-08-01 00:00:00'
AND co.upload_time <= '2022-08-31 59:59:59'
AND JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]') is NOT NULL
复制代码

 

 

索引生效:加上concat()函数

复制代码
EXPLAIN
SELECT
    dt.name AS deviceName,
    su.`name` AS userName,
    date_format(co.upload_time, '%Y%m%d') as time
FROM
    tb_cust_order co
INNER JOIN sys_user su ON co.work_id = su.id
INNER JOIN tb_device d ON d.id=CONCAT(JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]'))
INNER JOIN tb_device_type dt ON dt.id=d.device_type_id
WHERE
    co.unit_id = 1498576617260576769
AND co.`status` = 'SUCCESS'
AND co.upload_time >= '2022-08-01 00:00:00'
AND co.upload_time <= '2022-08-31 59:59:59'
AND JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]') is NOT NULL
复制代码

 

 

 

解决办法:

1
2
3
4
id=JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]')
慢查询原因:函数会导致索引失效
解决方案:包一层concat() 
id=CONCAT(JSON_EXTRACT(co.use_devices -> '$[0].tbDeviceId','$[0]'))

  

 
posted @   Peter.Jones  阅读(325)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
历史上的今天:
2019-09-21 java多线程技术: interrupt() 中断线程, 优雅停止线程及原理
2019-09-21 Disconnected from the target VM, address: '127.0.0.1:5984', transport: 'socket'
点击右上角即可分享
微信分享提示