程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL創立全文索引分享

MySQL創立全文索引分享

編輯:MySQL綜合教程

MySQL創立全文索引分享。本站提示廣大學習愛好者:(MySQL創立全文索引分享)文章只能為提供參考,不一定能成為您想要的結果。以下是MySQL創立全文索引分享正文


運用索引時數據庫功能優化的必備技藝之一。在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個字符。另外,假如查詢的字符串包括中止詞,那麼該中止詞將會被疏忽。
注:假如能夠,請盡量先創立表並拔出一切數據後再創立全文索引,而不要在創立表時就直接創立全文索引,由於前者比後者的全文索引效率要高。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved