MySQL的全文搜索

MySQL支持全文搜索,主要是解決Like查詢或其他多條件模糊查詢帶來的性能問題

以下文章內容主要介紹如何使用全文搜索;

另外本文主要介紹5.6及5.7+以上版本,過低版本在全文索引上與引擎(MyISAM、InnoDB)有些區別就不做過多介紹了,現在應該大部分都是用5.6+版本了

介紹在MySQL5.7以前版本不支持中文,同時會介紹如何支持中文的全文檢索

先介紹全文檢索配置

1、服務參數設置:可以在 my.cnf文件中添加全文檢索最小檢索字符,默認不支持空格,各種標點符號

[mysqld]
ft_min_word_len = 1
ngram_token_size = 1

[client]
ft_min_word_len = 1

2、創建全文索引的幾種方式:

以下主要介紹集中創建全文索引的方式,可以根據實際需要應用於不同的場景

2.1 創建表時創建全文索引(如下示例)

CREATE TABLE `test` (
    `name` char(12) NOT NULL DEFAULT '',
    `nickname` char(12) NOT NULL DEFAULT '',
    FULLTEXT KEY `name` (`name`,`nickname`)WITH PARSER ngram
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

2.2 通過alter table 的方式添加

ALTER TABLE `table_name` ADD FULLTEXT INDEX index_name (`column_name`)
-- 或者:
ALTER TABLE `table_name` ADD FULLTEXT index_name (`column_name`)
-- 如果是5.7且需要支持中文,請然如下(支持中文分詞的全文索引)
ALTER TABLE `test` ADD FULLTEXT INDEX index_name (`column_name`)WITH PARSER ngram;

2.3 直接通過create index方式

CREATE FULLTEXT INDEX index_name ON `table_name` (`column_name`)
## 也可以在創建索引的時候指定索引的長度
CREATE FULLTEXT INDEX index_name ON `table_name` (`column_name`(20))

3. 刪除全文索引

    3.1. 直接使用 drop index(注意:沒有 drop fulltext index 這種用法)

DROP INDEX username ON test;

    3.2. 使用 alter table的方式 

ALTER TABLE test DROP INDEX username;

4. 索引的使用

全文索引有自己的語法格式,使用 match 和 against 關鍵字


select * from table_name where match(name,nickname) against('xxx xxx');

4.1 按自然語言搜索模式查詢

SELECT * FROM test WHERE MATCH (name,nickname) AGAINST ('關鍵詞' IN NATURAL LANGUAGE MODE);

按布爾全文搜索模式查詢

匹配既有管理又有數據庫的記錄

SELECT * FROM test WHERE MATCH (name,nickname) AGAINST ('+數據庫 +管理' IN BOOLEAN MODE);

4.2 匹配有數據庫,但是沒有管理的記錄

SELECT * FROM test WHERE MATCH (name,nickname) AGAINST ('+數據庫 -管理' IN BOOLEAN MODE);

4.3 匹配MySQL,但是把數據庫的相關性降低

SELECT * FROM test WHERE MATCH (name,nickname) AGAINST ('>數據庫 +MySQL' INBOOLEAN MODE);

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章