mysql添加索引和不添加索引的區(qū)別及說明
mysql添加索引和不添加索引區(qū)別
在工作中遇到記錄日志的表查詢慢問題
定位到該sql語句后發(fā)現(xiàn)是一個(gè)非常簡單的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)過對sql的定位發(fā)現(xiàn),只要加上trigger_time時(shí)間過濾查詢,查詢速度就會變的非常慢,當(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í)間過濾的動作上,于是對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-05
MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解
這篇文章主要介紹了MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
MySQL分支和循環(huán)結(jié)構(gòu)方式
在MySQL中,IF函數(shù)用于根據(jù)條件返回不同的值,類似于Java的三目運(yùn)算符,CASE語句則提供了兩種形式:簡單CASE函數(shù)和搜索CASE函數(shù),分別類似于Java中的switch-case結(jié)構(gòu)和多重if判斷,這些控制流函數(shù)在數(shù)據(jù)庫查詢和數(shù)據(jù)處理中非常有用,可以實(shí)現(xiàn)復(fù)雜的邏輯判斷2024-10-10
Linux CentOS MySQL數(shù)據(jù)庫安裝配置教程
這篇文章主要為大家詳細(xì)介紹了Linux CentOS MySQL數(shù)據(jù)庫的安裝配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
openEuler?RPM方式安裝MySQL8的實(shí)現(xiàn)
本文主要介紹了openEuler?RPM方式安裝MySQL8的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01

