mysql建立全文索引

來源:互聯網
上載者:User

標籤:建立表   演算法   mysql   sign   篩選   sel   bsp   插入   模糊查詢   

原文連結:http://www.cnblogs.com/zhouguowei/p/5216316.html

 

使用索引時資料庫效能最佳化的必備技能之一。在MySql資料庫中,有四種索引:聚焦索引(主鍵索引)、普通索引、唯一索引以及我們這裡將要介紹的全文索引(FUNLLTEXT INDEX)。

 

全文索引(也稱全文檢索索引)是目前搜尋引擎使用的一種關鍵技術。它能夠利用【分詞技術】等多種演算法智能分析出文本文字中關鍵詞的頻率和重要性,然後按照一定的演算法規則智能地篩選出我們想要的搜尋結果。

 

在MySql中,建立全文索引相對比較簡單。例如:我們有一個文章表(article),其中有主鍵ID(id)、文章標題(title)、文章內容(content)三個欄位。現在我們希望能夠在title和content兩個列上建立全文索引,article表及全文索引的建立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;

 

上面就是在建立表的同時建立全文索引的SQL樣本。此外,如果我們要給已經存在的表的指定欄位建立全文索引,同樣以article表為例,我們可以使用如下SQL語句進行建立:

 

ALTER TABLE article ADD FULLTEXT INDEX fulltext_article(title,content);

 

在MySql中建立全文索引之後,現在就該瞭解如何使用了。眾所周知,在資料庫中進行模糊查詢是使用like關鍵字進行查詢的,例如:

 

SELECT * FROM article WHERE content LIKE ‘%查詢字串%’;

 

那麼,我們在使用全文索引也這樣使用嗎?當然不是,我們必須使用特有的文法才能使用全文索引進行查詢,例如,我們想要在article表的title和content列中全文檢索索引指定的查詢字串,我們可以如下編寫SQL語句:

 

SELECT * FROM article WHERE MATCH(title,content) AGAINST (‘查詢字串’);

 

強烈注意:MySql內建的全文索引只能用於資料庫引擎為MYISAM的資料表,如果是其他資料引擎,則全文索引不會生效。此外,MySql內建的全文索引只能對英文進行全文檢索索引,目前無法對中文進行全文檢索索引。如果需要對包含中文在內的文本資料進行全文檢索索引,我們需要採用Sphinx(斯芬克斯)/Coreseek技術來處理中文。

 

註:目前,使用MySql內建的全文索引時,如果查詢字串的長度過短將無法得到期望的搜尋結果。MySql全文索引所能找到的詞預設最小長度為4個字元。另外,如果查詢的字串包含停止詞,那麼該停止詞將會被忽略。

 

註:如果可能,請盡量先建立表並插入所有資料後再建立全文索引,而不要在建立表時就直接建立全文索引,因為前者比後者的全文索引效率要高。

mysql建立全文索引

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.