mysql5.7.25全文检索功能怎么使用
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,本篇内容介绍了"mysql5.7.25全文检索功能怎么使用"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所
千家信息网最后更新 2025年01月19日mysql5.7.25全文检索功能怎么使用
本篇内容介绍了"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全文检索功能怎么使用"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
全文
文章
内容
索引
全文检索
检索
功能
摘要
数据
标题
版本
中文
支持
引擎
数据库
时间
更多
知识
查询
实用
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
清科数据库技术工作
计算机网络技术三级考有编程吗
魔兽世界9.1服务器排名
上海数据库培训知乎
网页设计加sql数据库
服务器主机使用
服务器距离远
数据库技术题库及答案中英文
艾斯美尔数据库
网络安全黑板报布置书桌
达梦数据库更改数据文件名称
数据库使用排行
数据库安全性实验七
变速齿轮下载软件开发
企业数据库安全吗
铭诚网络安全有限公司
中国网络安全与信息化大学
贝尔的olt服务器
应用怎么调取数据库数据
t3建立的数据库已存在
国泰安数据库人物特征
新媒体与网络技术大学
家用文件服务器
数据库中的表对应三级模型中的
景安上怎么设置数据库
阿里云服务器可以预存资金吗
湖南郴州安卓软件开发工资多少
怎么用网吧服务器玩游戏
龙约连不上服务器
云数据库未来