当前位置:Gxlcms > 数据库问题 > MySql全文索引

MySql全文索引

时间:2021-07-01 10:21:17 帮助过:16人阅读

  • CREATE TABLE article (
  •     id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
  •     title VARCHAR(200),
  •     content TEXT,
  •     FULLTEXT (title, content) --在titlecontent列上创建全文索引
  • );
  • 上面就是在创建表的同时建立全文索引的SQL示例。此外,如果我们想要给已经存在的表的指定字段创建全文索引,同样以article表为例,我们可以使用如下SQL语句进行创建:

    1. --给现有的article表的titlecontent字段创建全文索引
    2. --索引名称为fulltext_article
    3. ALTER TABLE article
    4. ADD FULLTEXT INDEX fulltext_article (title, content)

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

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

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

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

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

    备注1:目前,使用MySQL自带的全文索引时,如果查询字符串的长度过短将无法得到期望的搜索结果。MySQL全文索引所能找到的词的默认最小长度为4个字符。另外,如果查询的字符串包含停止词,那么该停止词将会被忽略。

    备注2:如果可能,请尽量先创建表并插入所有数据后再创建全文索引,而不要在创建表时就直接创建全文索引,因为前者比后者的全文索引效率要高。

     

    本文出自:http://www.365mini.com/page/mysql-create-fulltext-index.htm

    推荐:http://www.cnblogs.com/tommy-huang/p/4483684.html

    MySql全文索引

    标签:检索   mysq   指定   如何使用   art   against   mys   算法   www   

    人气教程排行