3 回答

TA貢獻(xiàn)1834條經(jīng)驗(yàn) 獲得超8個(gè)贊
索引無(wú)法幫助文本與前導(dǎo)通配符匹配,索引可用于:
LIKE 'text%'
但是我猜這不會(huì)削減。對(duì)于這種類型的查詢,如果要擴(kuò)展可搜索的記錄數(shù)量,則確實(shí)應(yīng)該尋找全文搜索提供商。我首選的提供商是Sphinx,功能非常全/快速等。Lucene可能也值得一看。MyISAM表上的全文索引也可以使用,但是最終對(duì)于具有大量寫操作的任何數(shù)據(jù)庫(kù)追求MyISAM并不是一個(gè)好主意。

TA貢獻(xiàn)1856條經(jīng)驗(yàn) 獲得超5個(gè)贊
我要補(bǔ)充一點(diǎn),在某些情況下,如果您正在查看的字段通常為空或包含常量,則可以使用索引以及l(fā)ike / rlike來(lái)加快查詢速度。
在那種情況下,您似乎可以通過(guò)添加帶有固定值的“ and”子句來(lái)限制使用索引訪問的行。
我嘗試過(guò)在一個(gè)通常不包含很多標(biāo)簽的巨大表格中搜索“標(biāo)簽”。
SELECT * FROM objects WHERE tags RLIKE("((^|,)tag(,|$))" AND tags!=''
如果您在標(biāo)簽上有一個(gè)索引,則會(huì)看到它用于限制正在搜索的行。
添加回答
舉報(bào)