濮阳杆衣贸易有限公司

主頁 > 知識庫 > MySQL創(chuàng)建全文索引分享

MySQL創(chuàng)建全文索引分享

熱門標簽:清遠申請400電話 手機外呼系統(tǒng)違法嗎 地圖簡圖標注 沈陽智能外呼系統(tǒng)供應商 東莞外呼企業(yè)管理系統(tǒng) 谷歌地圖標注位置圖解 如何選擇優(yōu)質(zhì)的外呼系統(tǒng) 南通電銷外呼系統(tǒng)哪家強 桂林云電銷機器人收費

使用索引時數(shù)據(jù)庫性能優(yōu)化的必備技能之一。在MySql數(shù)據(jù)庫中,有四種索引:聚焦索引(主鍵索引)、普通索引、唯一索引以及我們這里將要介紹的全文索引(FUNLLTEXT INDEX)。

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

在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關(guān)鍵字進行查詢的,例如:

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技術(shù)來處理中文。

注:目前,使用MySql自帶的全文索引時,如果查詢字符串的長度過短將無法得到期望的搜索結(jié)果。MySql全文索引所能找到的詞默認最小長度為4個字符。另外,如果查詢的字符串包含停止詞,那么該停止詞將會被忽略。
注:如果可能,請盡量先創(chuàng)建表并插入所有數(shù)據(jù)后再創(chuàng)建全文索引,而不要在創(chuàng)建表時就直接創(chuàng)建全文索引,因為前者比后者的全文索引效率要高。

您可能感興趣的文章:
  • MySQL 全文索引的原理與缺陷
  • MySQL全文索引、聯(lián)合索引、like查詢、json查詢速度哪個快
  • MySQL全文索引實現(xiàn)簡單版搜索引擎實例代碼
  • MySQL全文索引應用簡明教程
  • 基于mysql全文索引的深入理解
  • MySQL 全文索引使用指南

標簽:常德 重慶 湖州 貴州 成都 內(nèi)蒙古 臨沂 天津

巨人網(wǎng)絡通訊聲明:本文標題《MySQL創(chuàng)建全文索引分享》,本文關(guān)鍵詞  MySQL,創(chuàng)建,全文,索引,分享,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL創(chuàng)建全文索引分享》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL創(chuàng)建全文索引分享的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    梓潼县| 阆中市| 禹州市| 轮台县| 横山县| 建瓯市| 朝阳县| 大理市| 宜黄县| 雷州市| 静安区| 喀喇沁旗| 宣恩县| 莎车县| 永清县| 汝阳县| 神农架林区| 安远县| 绥宁县| 深圳市| 云安县| 柳江县| 孟津县| 建瓯市| 乌苏市| 丰原市| 洪江市| 石狮市| 定州市| 新竹县| 留坝县| 蓬溪县| 克东县| 澄城县| 乐山市| 扎兰屯市| 平原县| 邻水| 北辰区| 界首市| 旺苍县|