【MySQL】sql優(yōu)化小調(diào)優(yōu)一例

前言:今天在生產(chǎn)環(huán)境抓到慢SQL一例亏娜,單獨拿出來執(zhí)行速度非常快蹬挺,我們拿出該SQL分析一下维贺。

原始SQL:

select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;

執(zhí)行計劃:

MariaDB [test]> explain select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+
| id   | select_type | table           | type | possible_keys                 | key                           | key_len | ref   | rows | Extra                       |
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+
|    1 | SIMPLE      | xwcmmetadatalog | ref  | IX_xwcmmetadatalog_METADATAID | IX_xwcmmetadatalog_METADATAID | 5       | const |    1 | Using where; Using filesort |
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+
1 row in set (0.00 sec)

我們可以看到該執(zhí)行計劃其實問題也不是很大,唯一需要注意的就是用到了文件排序巴帮,當MySQL SERVER io比較吃緊的時候大量執(zhí)行該SQL就會有問題了溯泣,所以我們優(yōu)化思路就是消除這個文件排序即可。
查看索引

MariaDB [test]> show index from xwcmmetadatalog;
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| Table           | Non_unique | Key_name                         | Seq_in_index | Column_name   | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
| xwcmmetadatalog |          0 | PRIMARY                          |            1 | METADATALOGID | A         |           0 |     NULL | NULL   |      | BTREE      |         |               |
| xwcmmetadatalog |          1 | IX_xwcmmetadatalog_SRCMETADATAID |            1 | SRCMETADATAID | A         |           0 |     NULL | NULL   | YES  | BTREE      |         |               |
| xwcmmetadatalog |          1 | IX_xwcmmetadatalog_METADATAID    |            1 | METADATAID    | A         |           0 |     NULL | NULL   | YES  | BTREE      |         |               |
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+
3 rows in set (0.00 sec)

我們看到執(zhí)行計劃用到的索引只包含METADATAID列榕茧,而我們的sql篩選條件不僅包含metadataid='4395597' 還用到了opertime來排序垃沦,所以我們針對這兩個字段建立索引即可。

MariaDB [test]> create index idx_medataid_opertime on xwcmmetadatalog(metadataid,opertime);
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

再次查看執(zhí)行計劃:

MariaDB [test]> explain select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+
| id   | select_type | table           | type | possible_keys                                       | key                   | key_len | ref   | rows | Extra                    |
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+
|    1 | SIMPLE      | xwcmmetadatalog | ref  | IX_xwcmmetadatalog_METADATAID,idx_medataid_opertime | idx_medataid_opertime | 5       | const |    1 | Using where; Using index |
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+
1 row in set (0.00 sec)

完美

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末雪猪,一起剝皮案震驚了整個濱河市栏尚,隨后出現(xiàn)的幾起案子起愈,更是在濱河造成了極大的恐慌只恨,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,430評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抬虽,死亡現(xiàn)場離奇詭異官觅,居然都是意外死亡,警方通過查閱死者的電腦和手機阐污,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,406評論 3 398
  • 文/潘曉璐 我一進店門休涤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人笛辟,你說我怎么就攤上這事功氨。” “怎么了手幢?”我有些...
    開封第一講書人閱讀 167,834評論 0 360
  • 文/不壞的土叔 我叫張陵捷凄,是天一觀的道長。 經(jīng)常有香客問我围来,道長跺涤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,543評論 1 296
  • 正文 為了忘掉前任监透,我火速辦了婚禮桶错,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘胀蛮。我一直安慰自己院刁,他們只是感情好,可當我...
    茶點故事閱讀 68,547評論 6 397
  • 文/花漫 我一把揭開白布粪狼。 她就那樣靜靜地躺著退腥,像睡著了一般超营。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上阅虫,一...
    開封第一講書人閱讀 52,196評論 1 308
  • 那天演闭,我揣著相機與錄音,去河邊找鬼颓帝。 笑死米碰,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的购城。 我是一名探鬼主播吕座,決...
    沈念sama閱讀 40,776評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼瘪板!你這毒婦竟也來了吴趴?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,671評論 0 276
  • 序言:老撾萬榮一對情侶失蹤侮攀,失蹤者是張志新(化名)和其女友劉穎锣枝,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兰英,經(jīng)...
    沈念sama閱讀 46,221評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡撇叁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,303評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了畦贸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片陨闹。...
    茶點故事閱讀 40,444評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖薄坏,靈堂內(nèi)的尸體忽然破棺而出趋厉,到底是詐尸還是另有隱情,我是刑警寧澤胶坠,帶...
    沈念sama閱讀 36,134評論 5 350
  • 正文 年R本政府宣布君账,位于F島的核電站,受9級特大地震影響涵但,放射性物質(zhì)發(fā)生泄漏杈绸。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,810評論 3 333
  • 文/蒙蒙 一矮瘟、第九天 我趴在偏房一處隱蔽的房頂上張望瞳脓。 院中可真熱鬧,春花似錦澈侠、人聲如沸劫侧。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,285評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽烧栋。三九已至写妥,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間审姓,已是汗流浹背珍特。 一陣腳步聲響...
    開封第一講書人閱讀 33,399評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留魔吐,地道東北人扎筒。 一個月前我還...
    沈念sama閱讀 48,837評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像酬姆,于是被迫代替她去往敵國和親嗜桌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,455評論 2 359

推薦閱讀更多精彩內(nèi)容