mysql5.7.25使用全文检索功能的实例教程
前言
1. 创建带有全文索引的表
2. 添加全文索引
3. 添加测试数据
4. 执行查询
5. 语法
总结
前言有时项目中需要用到全文检索功能,如果全文检索数量相对较小,并且不希望单独搭建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使用全文检索功能的文章就介绍到这了,更多相关mysql5.7.25使用全文检索内容请搜索易知道(ezd.cc)以前的文章或继续浏览下面的相关文章希望大家以后多多支持易知道(ezd.cc)!
相关内容
-
固定路由器如何设置固定无线路由器设置教程
固定路由器如何设置固定无线路由器设置教程,,如今我们的智能手...
-
如何升级Win8预装win7win7直接升级Win8教程呢
如何升级Win8预装win7win7直接升级Win8教程呢,,新一代微软Win8...
-
iPad的手势功能iPad4手势的使用教程
iPad的手势功能iPad4手势的使用教程,,可能有很多朋友刚刚接触...
-
用电脑给小米刷机教程视频教程|小米怎么用电脑
用电脑给小米刷机教程视频教程|小米怎么用电脑刷机教程,,小米...
-
小米盒子越狱教程|小米盒子如何越狱教程
小米盒子越狱教程|小米盒子如何越狱教程,,小米盒子如何越狱教...
-
怎么把电脑显卡清灰分享|显卡清灰教程
怎么把电脑显卡清灰分享|显卡清灰教程,,1. 显卡清灰教程1.首先...
-
影子系统是什么影子系统安装卸载win10影子系统
影子系统是什么影子系统安装卸载win10影子系统崩溃修复教程,...
-
Android手机模拟器的安装方法_模拟器安装教程在
Android手机模拟器的安装方法_模拟器安装教程在计算机技能,,核...
-
宏碁笔记本电脑预装Win8Win7系统图文教程
宏碁笔记本电脑预装Win8Win7系统图文教程,,宏碁笔记本电脑的Wi...
-
网络设置教程|如何网络设置
网络设置教程|如何网络设置,,如何网络设置wifi路由器信道的设...
-
电脑硬盘启动设置教程|电脑硬盘启动设置方法
电脑硬盘启动设置教程|电脑硬盘启动设置方法,,1. 电脑硬盘启动...
-
金蝶进销存教程软件|金蝶进销存管理软件最便宜
金蝶进销存教程软件|金蝶进销存管理软件最便宜的多少钱?都是...
-
笔记本电脑怎么更换内存条|笔记本电脑怎么更换
笔记本电脑怎么更换内存条|笔记本电脑怎么更换内存条视频教...
-
凤凰刷机教程|凤凰系统刷机包
凤凰刷机教程|凤凰系统刷机包,,凤凰系统刷机包手机刷机刷机就...
-
金蝶迷你版现金流量表操作教程|KIS迷你版现金流
金蝶迷你版现金流量表操作教程|KIS迷你版现金流量表的怎样操...