加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql学习MySQL创建全文索引分享

发布时间:2020-12-12 02:27:57 所属栏目:MySql教程 来源:网络整理
导读:《Mysql学习MySQL创建全文索引分享》要点: 本文介绍了Mysql学习MySQL创建全文索引分享,希望对您有用。如果有疑问,可以联系我们。 MYSQL教程 使用索引时数据库性能优化的必备技能之一.在MySql数据库中,有四种索引:聚焦索引(主键索引)、普通索引、唯一索引

《Mysql学习MySQL创建全文索引分享》要点:
本文介绍了Mysql学习MySQL创建全文索引分享,希望对您有用。如果有疑问,可以联系我们。

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

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

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

MYSQL教程
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;

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

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

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

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

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

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

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

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

《Mysql学习MySQL创建全文索引分享》是否对您有启发,欢迎查看更多与《Mysql学习MySQL创建全文索引分享》相关教程,学精学透。编程之家PHP学院为您提供精彩教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读