MySQL 全文索引使用指南
全文索引需要特殊的查詢語(yǔ)法。有沒(méi)有索引都可以進(jìn)行全文檢索,但是存在索引時(shí)會(huì)提高匹配的速度。全文索引的索引通過(guò)特殊的結(jié)構(gòu)存儲(chǔ)以便于找到文檔中包含搜索關(guān)鍵字對(duì)應(yīng)的內(nèi)容。在我們?nèi)粘I钪校畛R?jiàn)的全文檢索就是網(wǎng)絡(luò)搜索引擎。雖然,網(wǎng)絡(luò)搜索引擎的數(shù)據(jù)里十分龐大,并且通常也不會(huì)使用關(guān)系型數(shù)據(jù)庫(kù),但是原理是相似的。
全文索引支持通過(guò)基于字符(CHAR、VARCHAR 和 TEXT 類型的列)的檢索,也可以支持自然語(yǔ)言模式(Natural Language Mode, 默認(rèn))和布爾模式 (Boolean Mode)。例如我們搜索“數(shù)據(jù)庫(kù)引擎”的時(shí)候,內(nèi)容中包括“數(shù)據(jù)庫(kù)”、“引擎”和“數(shù)據(jù)庫(kù)引擎”的內(nèi)容都會(huì)檢索出來(lái)。全文索引的實(shí)現(xiàn)有大量的限制,而且十分復(fù)雜。但是由于內(nèi)置在MySQL服務(wù)端,而且對(duì)很多應(yīng)用都能夠滿足要求,因此被廣泛使用。
在MySQL5.6之前的版本中,只有 MyISAM 存儲(chǔ)引擎支持全文索引。創(chuàng)建全文索引需要指定列標(biāo)記為全文索引,如下面的 content 列。
CREATE TABLE t_news ( id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY, content TEXT, author VARCHAR(32), title VARCHAR(128), FULLTEXT (content) ) ENGINE=InnoDB;
MySQL 5.6以前對(duì)中文搜索支持不是太好,需要自己進(jìn)行分詞后將段落預(yù)處理拆分成單詞在入庫(kù)。MySQL5.7.6后才有了內(nèi)置的分詞器 ngram。ngram 支持設(shè)置設(shè)置分詞的長(zhǎng)度,可以將中文按長(zhǎng)度拆分為不同的單詞(雖然不太智能,但滿足大部分場(chǎng)景)。可以通過(guò) MySQL 的全局變量ngram_token_size設(shè)置分詞長(zhǎng)度,默認(rèn)是2,支持1-10可選。對(duì)于上面的例子,需要指定分詞器構(gòu)建全文索引。
CREATE TABLE t_news ( id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY, content TEXT, author VARCHAR(32), title VARCHAR(128), FULLTEXT KEY idx(content) WITH PARSER ngram ) ENGINE=InnoDB;
插入一條數(shù)據(jù)測(cè)試。
INSERT INTO `t_news`
(`id`, `content`, `author`, `title`)
VALUES ('1', '我有一個(gè)數(shù)據(jù)庫(kù)和引擎', '島上碼農(nóng)', '數(shù)據(jù)庫(kù)引擎');
在簡(jiǎn)單的模糊搜索中可以使用 LIKE 來(lái)完成,而對(duì)于全文檢索需要使用如下方式的語(yǔ)句:
SELECT * FROM t_news
WHERE MATCH (content) AGAINST ('數(shù)據(jù) 引擎' IN NATURAL LANGUAGE MODE)
通過(guò)這種方式可以檢索出剛剛插入的內(nèi)容,而如果使用 LIKE 是沒(méi)法完成的。也支持使用相關(guān)性排序,再插入一條數(shù)據(jù):
INSERT INTO `t_news` (`id`, `content`, `author`, `title`) VALUES (2,'我有一個(gè)數(shù)據(jù)庫(kù)','島上碼農(nóng)','數(shù)據(jù)庫(kù)')
然后執(zhí)行排序查詢:
SELECT *, MATCH (content) AGAINST ('數(shù)據(jù) 引擎' ) AS relevance
FROM t_news
WHERE MATCH (content) AGAINST ('數(shù)據(jù) 引擎' )
ORDER BY relevance ASC
這里將匹配值作為一列查詢,以便使用其別名進(jìn)行排序。相關(guān)性越高,對(duì)應(yīng)的 relevance 值越大,因此可以用作排序。入股不相關(guān),那么 relevance 的值為0。
布爾模式可以做更多的控制,例如包括使用+號(hào)保留匹配結(jié)果和使用-號(hào)排除匹配結(jié)果,下面的就匹配了數(shù)據(jù),而排除了包含引擎的數(shù)據(jù)。更多操作符可以參考 MySQL 的官方文檔:全文索引操作符。
SELECT * FROM t_news
WHERE MATCH (content) AGAINST ('+數(shù)據(jù)* -引擎' IN BOOLEAN MODE);
以上就是MySQL 全文索引使用指南的詳細(xì)內(nèi)容,更多關(guān)于MySQL 全文索引的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MySQL中SQL連接操作左連接查詢(LEFT?JOIN)示例詳解
這篇文章主要給大家介紹了關(guān)于MySQL中SQL連接操作左連接查詢(LEFT?JOIN)的相關(guān)資料,左連接(LEFT?JOIN)是SQL中用于連接兩個(gè)或多個(gè)表的一種操作,它返回左表的所有行,并根據(jù)連接條件從右表中匹配行,需要的朋友可以參考下2024-12-12
Mysql主從復(fù)制(master-slave)實(shí)際操作案例
這篇文章主要介紹了Mysql主從復(fù)制(master-slave)實(shí)際操作案例,同時(shí)介紹了Mysql grant 用戶授權(quán)的相關(guān)內(nèi)容,需要的朋友可以參考下2014-06-06
InnoDB中不同SQL語(yǔ)句設(shè)置鎖的情況詳解
這篇文章主要介紹了InnoDB中不同SQL語(yǔ)句設(shè)置鎖的情況詳解,在Mysql中,鎖定讀、更新、刪除操作通常會(huì)對(duì)SQL語(yǔ)句處理過(guò)程中掃描到的每條索引記錄設(shè)置記錄鎖,需要的朋友可以參考下2024-01-01
使用Shell腳本進(jìn)行MySql權(quán)限修改的實(shí)現(xiàn)教程
原先數(shù)據(jù)配置文件中有bind-address=127.0.0.1,注釋掉此配置后,原數(shù)據(jù)庫(kù)中默認(rèn)帶%root的權(quán)限,現(xiàn)在需要通過(guò)腳本實(shí)現(xiàn)白名單列表中的ip添加權(quán)限允許訪問(wèn)數(shù)據(jù)庫(kù),本文給大家介紹了使用Shell腳本進(jìn)行MySql權(quán)限修改的實(shí)現(xiàn)教程,需要的朋友可以參考下2024-03-03
MYSQL時(shí)區(qū)導(dǎo)致時(shí)間差了14或13小時(shí)的解決方法
本文主要介紹了MYSQL時(shí)區(qū)導(dǎo)致時(shí)間差了14或13小時(shí)的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-01-01
windows環(huán)境下mysql數(shù)據(jù)庫(kù)的主從同步備份步驟(單向同步)
本文主要是向大家描述的是在windows環(huán)境之下實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)的主從同步備份的正確操作方案,以下就是文章的詳細(xì)內(nèi)容描述2011-05-05
MySQL占用內(nèi)存較大與CPU過(guò)高測(cè)試與解決辦法
為了裝mysql環(huán)境測(cè)試,裝上后發(fā)現(xiàn)啟動(dòng)后MySQL占用內(nèi)存了很大,達(dá)8百多兆。網(wǎng)上搜索了一下,得到高人指點(diǎn)my.ini。再也沒(méi)見(jiàn)再詳細(xì)的了..只好打開my.ini逐行的啃,雖然英文差了點(diǎn),不過(guò)多少M(fèi)還是看得明的2018-03-03
mysql5.7數(shù)據(jù)庫(kù)安裝完成后如何配置環(huán)境變量
這篇文章主要為大家詳細(xì)介紹了在win10系統(tǒng)下,mysql5.7數(shù)據(jù)庫(kù)安裝完成后配置環(huán)境變量的具體步驟,感興趣的小伙伴們可以參考一下2016-06-06
Mysql根據(jù)時(shí)間查詢?nèi)掌诘膬?yōu)化技巧
這篇文章主要介紹了Mysql根據(jù)時(shí)間查詢?nèi)掌诘膬?yōu)化技巧,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2018-03-03

