欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql添加索引和不添加索引的區(qū)別及說明

 更新時(shí)間:2024年01月27日 16:41:21   作者:Ense  
這篇文章主要介紹了mysql添加索引和不添加索引的區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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問題的解決

    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 select緩存機(jī)制使用詳解

    mysql select緩存機(jī)制使用詳解

    這篇文章主要介紹了mysql select緩存機(jī)制使用詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解

    MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解

    這篇文章主要介紹了MySQL數(shù)據(jù)歸檔小工具mysql_archiver詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • MySQL5.1忘記root密碼的解決辦法(親測(cè))

    MySQL5.1忘記root密碼的解決辦法(親測(cè))

    這篇文章主要介紹了MySQL5.1忘記root密碼的解決辦法(親測(cè))的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • MySQL中的binary類型使用操作

    MySQL中的binary類型使用操作

    這篇文章主要介紹了MySQL中的binary類型使用操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • linux mysql 安裝與操作

    linux mysql 安裝與操作

    mysql是linux平臺(tái)下最流行的數(shù)據(jù)庫系統(tǒng),今天介紹的是mysql的安裝及簡(jiǎn)單的操作方法!
    2009-06-06
  • MySQL分支和循環(huán)結(jié)構(gòu)方式

    MySQL分支和循環(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-10
  • Linux CentOS MySQL數(shù)據(jù)庫安裝配置教程

    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)

    本文主要介紹了openEuler?RPM方式安裝MySQL8的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Linux安裝MySQL5.6.24使用文字說明

    Linux安裝MySQL5.6.24使用文字說明

    這篇文章主要為大家詳細(xì)介紹了Linux安裝MySQL使用文字說明,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評(píng)論