亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

我什么時候應該使用復合索引?

我什么時候應該使用復合索引?

紅糖糍粑 2019-08-12 11:10:50
我什么時候應該使用復合索引?我應該何時在數據庫中使用復合索引?使用復合索引的性能分支是什么?我為什么要使用復合索引?例如,我有一張homes桌子:CREATE TABLE IF NOT EXISTS `homes` (   `home_id` int(10) unsigned NOT NULL auto_increment,   `sqft` smallint(5) unsigned NOT NULL,   `year_built` smallint(5) unsigned NOT NULL,   `geolat` decimal(10,6) default NULL,   `geolng` decimal(10,6) default NULL,   PRIMARY KEY  (`home_id`),   KEY `geolat` (`geolat`),   KEY `geolng` (`geolng`),) ENGINE=InnoDB  ;是否有意義,我使用的復合指數都geolat和geolng,這樣的:我替換:  KEY `geolat` (`geolat`),   KEY `geolng` (`geolng`),有:KEY `geolat_geolng` (`geolat`, `geolng`)如果是這樣:為什么?使用復合索引的性能分支是什么?我不太明白如何閱讀EXPLAIN命令。這看起來好還是壞?,F在,我沒有使用geolat和geolng的綜合指數。我可以做?
查看完整描述

3 回答

?
慕的地10843

TA貢獻1785條經驗 獲得超8個贊

在使用受益的查詢時,應使用復合索引。一個如下所示的復合索引:

index( column_A, column_B, column_C )

將使用這些字段進行連接,過濾和有時選擇的查詢受益。它還將有益于使用該組合中最左側列的子集的查詢。所以上面的索引也將滿足需要的查詢

index( column_A, column_B, column_C )index( column_A, column_B )index( column_A )

但它不會(至少不直接,也許它可以幫助部分,如果沒有更好的索引)幫助查詢需要

index( column_A, column_C )

注意column_B是如何丟失的。

在您的原始示例中,兩個維度的復合索引將主要有益于在兩個維度或最左側維度上查詢的查詢,而不是最右側維度。如果你總是在查詢兩個維度,那么復合索引是要走的路,首先(最有可能)并不重要。


查看完整回答
反對 回復 2019-08-12
  • 3 回答
  • 0 關注
  • 1118 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號