MySQL支持全文搜索,主要是解決Like查詢或其他多條件模糊查詢帶來的性能問題
以下文章內容主要介紹如何使用全文搜索;
另外本文主要介紹5.6及5.7+以上版本,過低版本在全文索引上與引擎(MyISAM、InnoDB)有些區別就不做過多介紹了,現在應該大部分都是用5.6+版本了
介紹在MySQL5.7以前版本不支持中文,同時會介紹如何支持中文的全文檢索
先介紹全文檢索配置
1、服務參數設置:可以在 my.cnf文件中添加全文檢索最小檢索字符,默認不支持空格,各種標點符號
[mysqld]
## 關鍵字最小長度
ft_min_word_len = 1
## 中文分詞最小長度,默認為2
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);