mysql5.7.25全文檢索功能怎麼使用

王林
發布: 2023-05-28 17:34:06
轉載
1615 人瀏覽過

前言

有時專案中需要用到全文檢索功能,如果全文檢索數量相對較小,且不希望單獨搭建elasticsearch這樣的專用索引工具,就可以考慮使用mysql自帶的全文檢索功能。

mysql 5.7.25自帶的全文檢索功能,有一定的方便性。

在MySQL 5.7.6之前,全文索引只支援英文全文索引,不支援中文全文索引,需要利用分詞器把中文段落預處理分割成單字,然後存入資料庫。

從MySQL 5.7.6開始,MySQL內建了ngram全文解析器,用來支援中文、日文、韓文分詞。

本文使用的MySQL 版本是5.7.25,InnoDB資料庫引擎。

1. 建立有全文索引的表格

CREATE TABLE `tbl_article_content` (
  `id` bigint(40) NOT NULL AUTO_INCREMENT,
  `article_title` varchar(60) COMMENT '标题',
  `article_summary` varchar(120) COMMENT '摘要',
  `article_content` text NOT NULL COMMENT '内容',
  `article_id` bigint(40) NOT NULL COMMENT '对应文章ID',
  `create_date` datetime NOT NULL COMMENT '创建时间',
  `modified_date` datetime NOT NULL COMMENT '更新时间',
  PRIMARY KEY (`id`) USING BTREE,
  KEY `artid` (`article_id`) USING BTREE,
  FULLTEXT KEY `article_content` (`article_content`) /*!50100 WITH PARSER `ngram` */ 
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC;
登入後複製

/*!50100   */ 它表示5.01.00 版本或更高的版本,才執行.

 WITH PARSER `ngram`是指定分詞引擎。

2. 新增全文索引

如果在建立表格的時候未新增全文索引,可以在建表之後進行新增。

create fulltext index article_content on tbl_article_content(article_content) WITH PARSER ngram;
登入後複製

3. 新增測試資料

INSERT INTO `tbl_article_content` VALUES ('2', '文章标题', '文章摘要', '文章内容', '2', '2022-02-05 13:47:55', '2022-02-05 13:47:59');
登入後複製

4.執行查詢

mysql> select * FROM tbl_article_content222 WHERE MATCH(article_content) AGAINST('内容');
+----+---------------+-----------------+-----------------+------------+---------------------+---------------------+
| id | article_title | article_summary | article_content | article_id | create_date         | modified_date       |
+----+---------------+-----------------+-----------------+------------+---------------------+---------------------+
|  2 | 文章标题      | 文章摘要        | 文章内容        |          2 | 2022-02-05 13:47:55 | 2022-02-05 13:47:59 |
+----+---------------+-----------------+-----------------+------------+---------------------+---------------------+
1 row in set
登入後複製

全文查詢的關鍵字為MATCH和AGAINST。

5. 語法

MATCH (col1,col2,...) AGAINST (expr [search_modifier])
search_modifier: { IN BOOLEAN MODE | WITH QUERY EXPANSION }
登入後複製

 例如:SELECT * FROM tab_name WHERE MATCH (' 列名1,列名2...列名n') AGAINST('字1 字2 字3 .... 字m');

 即:MATCH 相當於要符合的列,而AGAINST 是要找出的內容。

以上是mysql5.7.25全文檢索功能怎麼使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!