mysql添加索引和不添加索引的區(qū)別及說明
mysql添加索引和不添加索引區(qū)別
在工作中遇到記錄日志的表查詢慢問題
定位到該sql語句后發(fā)現(xiàn)是一個(gè)非常簡(jiǎn)單的select查詢
SELECT t.id, t.job_group, t.job_id, t.executor_address, t.executor_handler, t.executor_param, t.executor_sharding_param, t.executor_fail_retry_count, t.trigger_time, t.trigger_code, t.trigger_msg, t.handle_time, t.handle_code, t.handle_msg, t.alarm_status FROM xxl_job_log AS t WHERE t.trigger_time >= '2020-01-01 00:00:00.0' AND t.trigger_time <= '2020-01-01 23:59:59.0' AND alarm_status = 0 ORDER BY t.trigger_time DESC LIMIT 0, 10
查詢目前表數(shù)據(jù)條數(shù)
八百多萬條數(shù)據(jù)
通過使用explain 定位看到
- 查詢類型:全表掃描
- 掃描條數(shù):7889316
- 執(zhí)行sql耗時(shí):9.563s
經(jīng)過對(duì)sql的定位發(fā)現(xiàn),只要加上trigger_time時(shí)間過濾查詢,查詢速度就會(huì)變的非常慢,當(dāng)去掉
t.trigger_time >= '2020-01-01 00:00:00.0' AND t.trigger_time <= '2020-01-01 23:59:59.0'
和
ORDER BY t.trigger_time DESC
- 后在執(zhí)行sql:0.002s
因此知道時(shí)間都花在了時(shí)間過濾的動(dòng)作上,于是對(duì)trigger_time做了索引操作:
ALTER TABLE xxl_job_log ADD INDEX index_job_time (trigger_time)
在使用explain查看select執(zhí)行情況
- 掃描范圍:局部
- 掃描條數(shù):694454
- 執(zhí)行sql耗時(shí):0.002s
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL數(shù)據(jù)同步出現(xiàn)Slave_IO_Running:?No問題的解決
本人最近工作中遇到了Slave_IO_Running:NO報(bào)錯(cuò)的情況,通過查找相關(guān)資料終于解決了,下面這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)同步出現(xiàn)Slave_IO_Running:?No問題的解決方法,需要的朋友可以參考下2023-05-05MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解
這篇文章主要介紹了MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12MySQL分支和循環(huán)結(jié)構(gòu)方式
在MySQL中,IF函數(shù)用于根據(jù)條件返回不同的值,類似于Java的三目運(yùn)算符,CASE語句則提供了兩種形式:簡(jiǎn)單CASE函數(shù)和搜索CASE函數(shù),分別類似于Java中的switch-case結(jié)構(gòu)和多重if判斷,這些控制流函數(shù)在數(shù)據(jù)庫查詢和數(shù)據(jù)處理中非常有用,可以實(shí)現(xiàn)復(fù)雜的邏輯判斷2024-10-10Linux CentOS MySQL數(shù)據(jù)庫安裝配置教程
這篇文章主要為大家詳細(xì)介紹了Linux CentOS MySQL數(shù)據(jù)庫的安裝配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05openEuler?RPM方式安裝MySQL8的實(shí)現(xiàn)
本文主要介紹了openEuler?RPM方式安裝MySQL8的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01