亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2017年01月09日 21:53:49   投稿:mdxy-dxy  
使用索引是數(shù)據(jù)庫性能優(yōu)化的必備技能之一。在MySQL數(shù)據(jù)庫中,有四種索引:聚集索引(主鍵索引)、普通索引、唯一索引以及我們這里將要介紹的全文索引(FULLTEXT INDEX)

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

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

在MySql中,創(chuàng)建全文索引相對比較簡單。例如:我們有一個文章表(article),其中有主鍵ID(id)、文章標(biāo)題(title)、文章內(nèi)容(content)三個字段。現(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 ‘%查詢字符串%';

那么,我們在使用全文索引也這樣使用嗎?當(dāng)然不是,我們必須使用特有的語法才能使用全文索引進行查詢,例如,我們想要在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全文索引所能找到的詞默認(rèn)最小長度為4個字符。另外,如果查詢的字符串包含停止詞,那么該停止詞將會被忽略。
注:如果可能,請盡量先創(chuàng)建表并插入所有數(shù)據(jù)后再創(chuàng)建全文索引,而不要在創(chuàng)建表時就直接創(chuàng)建全文索引,因為前者比后者的全文索引效率要高。

相關(guān)文章

  • CentOS 5.5下安裝MySQL 5.5全過程分享

    CentOS 5.5下安裝MySQL 5.5全過程分享

    網(wǎng)絡(luò)上有很多相關(guān)的安裝筆記,但是并不詳盡,或是編譯環(huán)境稍有不同,過程就會有差異,所以我總結(jié)了已有的經(jīng)驗和我自己安裝過程中的體驗,擴充并詳盡地記錄了整個過程。我選擇安裝的是MySQL5.5.27版本。以下是我的安裝筆記
    2012-09-09
  • 淺談mysql數(shù)據(jù)庫中的using的用法

    淺談mysql數(shù)據(jù)庫中的using的用法

    在用Join進行多表聯(lián)合查詢時,我們通常使用On來建立兩個表的關(guān)系。其實還有一個更方便的關(guān)鍵字,那就是Using。
    2015-04-04
  • C++與mysql連接遇到的問題匯總

    C++與mysql連接遇到的問題匯總

    下面小編給大家介紹c++與mysql連接的思路詳解及遇到問題匯總,非常不錯,感興趣的朋友參考下吧
    2016-08-08
  • 最新MySql8.27主從復(fù)制及SpringBoot項目中的讀寫分離實戰(zhàn)教程

    最新MySql8.27主從復(fù)制及SpringBoot項目中的讀寫分離實戰(zhàn)教程

    MySQL主從復(fù)制是一個異步的復(fù)制過程,底層是基于MySQL1數(shù)據(jù)庫自帶的二進制日志功能,這篇文章主要介紹了最新MySql8.27主從復(fù)制及SpringBoot項目中的讀寫分離實戰(zhàn)教程,需要的朋友可以參考下
    2022-08-08
  • centos 7系統(tǒng)下編譯安裝 mysql5.7教程

    centos 7系統(tǒng)下編譯安裝 mysql5.7教程

    因為Mysql5.7的更新特性還是非常多,所以這篇文章就給大家介紹以下在centos上面編譯安裝mysql5.7的教程。本文給大家介紹的步驟還是相對來說比較詳細的,相信對大家具有一定的參考借鑒價值,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-11-11
  • 用MyEclipse配置DataBase Explorer(圖示)

    用MyEclipse配置DataBase Explorer(圖示)

    本文介紹了,用MyEclipse配置DataBase Explorer的圖片示例。需要的朋友參考下
    2013-04-04
  • SQL實現(xiàn)LeetCode(184.系里最高薪水)

    SQL實現(xiàn)LeetCode(184.系里最高薪水)

    這篇文章主要介紹了SQL實現(xiàn)LeetCode(184.系里最高薪水),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Mysql避免重復(fù)插入數(shù)據(jù)的4種方式

    Mysql避免重復(fù)插入數(shù)據(jù)的4種方式

    這篇文章主要介紹了Mysql避免重復(fù)插入數(shù)據(jù)的4種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MySQL 5.7 zip版本(zip版)安裝配置步驟詳解

    MySQL 5.7 zip版本(zip版)安裝配置步驟詳解

    這篇文章主要介紹了MySQL 5.7 zip版本(zip版)安裝配置步驟詳解,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-02-02
  • mysql?ON?DUPLICATE?KEY?UPDATE重復(fù)插入時更新方式

    mysql?ON?DUPLICATE?KEY?UPDATE重復(fù)插入時更新方式

    這篇文章主要介紹了mysql?ON?DUPLICATE?KEY?UPDATE重復(fù)插入時更新方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07

最新評論