91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2022-02-07 14:47:02 來源:億速云 閱讀:194 作者:iii 欄目:開發技術

本篇內容介紹了“mysql5.7.25全文檢索功能怎么使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

前言

有時項目中需要用到全文檢索功能,如果全文檢索數量相對較小,并且不希望單獨搭建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全文檢索功能怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

龙山县| 兴城市| 昆明市| 宜都市| 黔江区| 夏邑县| 宝鸡市| 枣阳市| 隆化县| 三亚市| 甘洛县| 凤台县| 景泰县| 渝中区| 时尚| 项城市| 仁布县| 黄浦区| 新蔡县| 镇巴县| 南开区| 丹东市| 仪征市| 内江市| 衡东县| 老河口市| 汉中市| 宜川县| 横山县| 历史| 雅安市| 伊金霍洛旗| 福贡县| 宜春市| 澜沧| 博爱县| 庆阳市| 买车| 屏南县| 呈贡县| 灵璧县|