mysql创建全文索引
原文鏈接:http://www.cnblogs.com/zhouguowei/p/5216316.html
?
使用索引時數(shù)據(jù)庫性能優(yōu)化的必備技能之一。在MySql數(shù)據(jù)庫中,有四種索引:聚焦索引(主鍵索引)、普通索引、唯一索引以及我們這里將要介紹的全文索引(FUNLLTEXT?INDEX)。
?
全文索引(也稱全文檢索)是目前搜索引擎使用的一種關鍵技術。它能夠利用【分詞技術】等多種算法智能分析出文本文字中關鍵詞的頻率和重要性,然后按照一定的算法規(guī)則智能地篩選出我們想要的搜索結果。
?
在MySql中,創(chuàng)建全文索引相對比較簡單。例如:我們有一個文章表(article),其中有主鍵ID(id)、文章標題(title)、文章內(nèi)容(content)三個字段?,F(xiàn)在我們希望能夠在title和content兩個列上創(chuàng)建全文索引,article表及全文索引的創(chuàng)建SQL語句如下:
CREATE?TABLE?`article`?(
??`id`?int(10)?unsigned?NOT?NULL?AUTO_INCREMENT,
??`title`?varchar(200)?DEFAULT?NULL,
??`content`?text,
??PRIMARY?KEY?(`id`),
??FULLTEXT?KEY?`title`?(`title`,`content`)
)?ENGINE=MyISAM?DEFAULT?CHARSET=utf8;
?
上面就是在創(chuàng)建表的同時創(chuàng)建全文索引的SQL示例。此外,如果我們要給已經(jīng)存在的表的指定字段創(chuàng)建全文索引,同樣以article表為例,我們可以使用如下SQL語句進行創(chuàng)建:
?
ALTER?TABLE?article?ADD?FULLTEXT?INDEX?fulltext_article(title,content);
?
在MySql中創(chuàng)建全文索引之后,現(xiàn)在就該了解如何使用了。眾所周知,在數(shù)據(jù)庫中進行模糊查詢是使用like關鍵字進行查詢的,例如:
?
SELECT?*?FROM?article?WHERE?content?LIKE?‘%查詢字符串%’;
?
那么,我們在使用全文索引也這樣使用嗎?當然不是,我們必須使用特有的語法才能使用全文索引進行查詢,例如,我們想要在article表的title和content列中全文檢索指定的查詢字符串,我們可以如下編寫SQL語句:
?
SELECT?*?FROM?article?WHERE?MATCH(title,content)?AGAINST?(‘查詢字符串’);
?
強烈注意:MySql自帶的全文索引只能用于數(shù)據(jù)庫引擎為MYISAM的數(shù)據(jù)表,如果是其他數(shù)據(jù)引擎,則全文索引不會生效。此外,MySql自帶的全文索引只能對英文進行全文檢索,目前無法對中文進行全文檢索。如果需要對包含中文在內(nèi)的文本數(shù)據(jù)進行全文檢索,我們需要采用Sphinx(斯芬克斯)/Coreseek技術來處理中文。
?
注:目前,使用MySql自帶的全文索引時,如果查詢字符串的長度過短將無法得到期望的搜索結果。MySql全文索引所能找到的詞默認最小長度為4個字符。另外,如果查詢的字符串包含停止詞,那么該停止詞將會被忽略。
?
注:如果可能,請盡量先創(chuàng)建表并插入所有數(shù)據(jù)后再創(chuàng)建全文索引,而不要在創(chuàng)建表時就直接創(chuàng)建全文索引,因為前者比后者的全文索引效率要高。
轉(zhuǎn)載于:https://www.cnblogs.com/hxphp/p/7089314.html
總結
以上是生活随笔為你收集整理的mysql创建全文索引的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 九度OJ 1435:迷瘴
- 下一篇: 解决oracle数据库连接不上的问题