mysql添加索引和不添加索引的區(qū)別及說明
更新時間:2024年01月27日 16:41:21 作者:Ense
這篇文章主要介紹了mysql添加索引和不添加索引的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
mysql添加索引和不添加索引區(qū)別
在工作中遇到記錄日志的表查詢慢問題
定位到該sql語句后發(fā)現(xià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耗時:9.563s
經(jīng)過對sql的定位發(fā)現(xiàn),只要加上trigger_time時間過濾查詢,查詢速度就會變的非常慢,當去掉
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
因此知道時間都花在了時間過濾的動作上,于是對trigger_time做了索引操作:
ALTER TABLE xxl_job_log ADD INDEX index_job_time (trigger_time)
在使用explain查看select執(zhí)行情況
- 掃描范圍:局部
- 掃描條數(shù):694454
- 執(zhí)行sql耗時:0.002s
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
MySQL數(shù)據(jù)同步出現(xiàn)Slave_IO_Running:?No問題的解決
本人最近工作中遇到了Slave_IO_Running:NO報錯的情況,通過查找相關資料終于解決了,下面這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)同步出現(xiàn)Slave_IO_Running:?No問題的解決方法,需要的朋友可以參考下2023-05-05MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解
這篇文章主要介紹了MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12MySQL分支和循環(huán)結(jié)構(gòu)方式
在MySQL中,IF函數(shù)用于根據(jù)條件返回不同的值,類似于Java的三目運算符,CASE語句則提供了兩種形式:簡單CASE函數(shù)和搜索CASE函數(shù),分別類似于Java中的switch-case結(jié)構(gòu)和多重if判斷,這些控制流函數(shù)在數(shù)據(jù)庫查詢和數(shù)據(jù)處理中非常有用,可以實現(xiàn)復雜的邏輯判斷2024-10-10Linux CentOS MySQL數(shù)據(jù)庫安裝配置教程
這篇文章主要為大家詳細介紹了Linux CentOS MySQL數(shù)據(jù)庫的安裝配置教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-05-05openEuler?RPM方式安裝MySQL8的實現(xiàn)
本文主要介紹了openEuler?RPM方式安裝MySQL8的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01