MySQL创建全文索引分享

作者:mdxy-dxy 时间:2024-01-21 10:16:06 

使用索引时数据库性能优化的必备技能之一。在MySql数据库中,有四种索引:聚焦索引(主键索引)、普通索引、唯一索引以及我们这里将要介绍的全文索引(FUNLLTEXT INDEX)。

全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用【分词技术】等多种算法智能分析出文本文字中关键词的频率和重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。

在MySql中,创建全文索引相对比较简单。例如:我们有一个文章表(article),其中有主键ID(id)、文章标题(title)、文章内容(content)三个字段。现在我们希望能够在title和content两个列上创建全文索引,article表及全文索引的创建SQL语句如下:


CREATE TABLE `article` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`title` varchar(200) DEFAULT NULL,
`content` text,
PRIMARY KEY (`id`),
FULLTEXT KEY `title` (`title`,`content`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

上面就是在创建表的同时创建全文索引的SQL示例。此外,如果我们要给已经存在的表的指定字段创建全文索引,同样以article表为例,我们可以使用如下SQL语句进行创建:


ALTER TABLE article ADD FULLTEXT INDEX fulltext_article(title,content);

在MySql中创建全文索引之后,现在就该了解如何使用了。众所周知,在数据库中进行模糊查询是使用like关键字进行查询的,例如:


SELECT * FROM article WHERE content LIKE ‘%查询字符串%';

那么,我们在使用全文索引也这样使用吗?当然不是,我们必须使用特有的语法才能使用全文索引进行查询,例如,我们想要在article表的title和content列中全文检索指定的查询字符串,我们可以如下编写SQL语句:


SELECT * FROM article WHERE MATCH(title,content) AGAINST (‘查询字符串');

强烈注意:MySql自带的全文索引只能用于数据库引擎为MYISAM的数据表,如果是其他数据引擎,则全文索引不会生效。此外,MySql自带的全文索引只能对英文进行全文检索,目前无法对中文进行全文检索。如果需要对包含中文在内的文本数据进行全文检索,我们需要采用Sphinx(斯芬克斯)/Coreseek技术来处理中文。

注:目前,使用MySql自带的全文索引时,如果查询字符串的长度过短将无法得到期望的搜索结果。MySql全文索引所能找到的词默认最小长度为4个字符。另外,如果查询的字符串包含停止词,那么该停止词将会被忽略。
注:如果可能,请尽量先创建表并插入所有数据后再创建全文索引,而不要在创建表时就直接创建全文索引,因为前者比后者的全文索引效率要高。

标签:MySQL,全文索引
0
投稿

猜你喜欢

  • Python可执行文件反编译教程(exe转py)

    2022-05-07 19:37:11
  • keras实现调用自己训练的模型,并去掉全连接层

    2023-08-10 16:34:21
  • js DOM模型操作

    2024-05-13 09:37:18
  • js+css实现select的美化效果

    2024-04-16 09:52:25
  • Python零基础入门学习之输入与输出

    2023-07-22 09:50:12
  • 基于python实现获取网页图片过程解析

    2023-10-08 21:57:59
  • SpringBoot Security使用MySQL实现验证与权限管理

    2024-01-22 15:32:00
  • Sql 语句学习指南第1/2页

    2024-01-25 07:13:01
  • 解读ASP.NET 5 & MVC6系列教程(13):TagHelper

    2024-05-03 15:30:35
  • 原生js实现波浪导航效果

    2024-04-17 10:06:25
  • 关于Python 3中print函数的换行详解

    2021-04-09 09:57:48
  • IDA Pro 6.0使用Qt框架实现了跨平台的UI界面

    2022-12-05 05:07:55
  • JetBrains(IEDA、CLion、Pycharm) 学生获得免费使用资格

    2022-02-21 09:25:35
  • 使用ASP脚本命令重新启动服务器

    2008-10-10 11:53:00
  • Js实现粘贴上传图片的原理及示例

    2024-04-19 10:44:50
  • Python实现把回车符\\r\\n转换成\\n

    2022-09-21 07:22:14
  • python字典序问题实例

    2023-07-31 05:46:58
  • javascript获取wx.config内部字段解决微信分享

    2024-04-23 09:15:50
  • Python中的异常处理学习笔记

    2023-06-26 05:04:29
  • python实现简单学生信息管理系统

    2022-01-28 12:40:00
  • asp之家 网络编程 m.aspxhome.com