我什么時候應(yīng)該使用復(fù)合索引?我應(yīng)該何時在數(shù)據(jù)庫中使用復(fù)合索引?使用復(fù)合索引的性能分支是什么?我為什么要使用復(fù)合索引?例如,我有一張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 ;是否有意義,我使用的復(fù)合指數(shù)都geolat和geolng,這樣的:我替換: KEY `geolat` (`geolat`),
KEY `geolng` (`geolng`),有:KEY `geolat_geolng` (`geolat`, `geolng`)如果是這樣:為什么?使用復(fù)合索引的性能分支是什么?我不太明白如何閱讀EXPLAIN命令。這看起來好還是壞?,F(xiàn)在,我沒有使用geolat和geolng的綜合指數(shù)。我可以做?
3 回答

慕的地10843
TA貢獻1785條經(jīng)驗 獲得超8個贊
在使用受益的查詢時,應(yīng)使用復(fù)合索引。一個如下所示的復(fù)合索引:
index( column_A, column_B, column_C )
將使用這些字段進行連接,過濾和有時選擇的查詢受益。它還將有益于使用該組合中最左側(cè)列的子集的查詢。所以上面的索引也將滿足需要的查詢
index( column_A, column_B, column_C )index( column_A, column_B )index( column_A )
但它不會(至少不直接,也許它可以幫助部分,如果沒有更好的索引)幫助查詢需要
index( column_A, column_C )
注意column_B是如何丟失的。
在您的原始示例中,兩個維度的復(fù)合索引將主要有益于在兩個維度或最左側(cè)維度上查詢的查詢,而不是最右側(cè)維度。如果你總是在查詢兩個維度,那么復(fù)合索引是要走的路,首先(最有可能)并不重要。
添加回答
舉報
0/150
提交
取消