mysql引擎innodb和mysiam,全文索引,又称全文检索

innodb和mysiam引擎的主要区别:
MyISAM引擎是MySQL 5.1及以前版本的默认引擎,它的特色是:html

一、不支持行锁,读取时对须要读到的全部表加锁,写入时则对表加排它锁
二、不支持事务
三、不支持外键
四、不支持崩溃后的安全恢复
五、在表有读取查询的同时,支持往表中插入新纪录
六、支持BLOB和TEXT的前500个字符索引,支持全文索引
七、支持延迟更新索引,极大提高写入性能
八、对于不会进行修改的表,支持压缩表,极大减小磁盘空间占用mysql

InnoDB
InnoDB在MySQL 5.5后成为默认索引,它的特色是:算法

一、支持行锁,采用MVCC来支持高并发
二、支持事务
三、支持外键
四、支持崩溃后的安全恢复
五、不支持全文索引sql

看到全文索引了解以下:
先总结:
一、全文索引只支持MYSIAM数据库引擎,只支持英文全文索引;
二、想用全文索引,好比查询用到like,语句要改为 SELECT * FROM article WHERE MATCH(title, content) AGAINST('查询字符串') ;
三、尽可能在数据表中插入较多的数据后再建立全文索引。数据库

如下为网络上总结的详细内容:
网址http://www.javashuo.com/article/p-phmgsshs-ba.html
MySql全文索引
使用索引是数据库性能优化的必备技能之一。在MySQL数据库中,有四种索引:汇集索引(主键索引)、普通索引、惟一索引以及咱们这里将要介绍的全文索引(FULLTEXT INDEX)。安全

全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它可以利用「分词技术「等多种算法智能分析出文本文字中关键字词的频率及重要性,而后按照必定的算法规则智能地筛选出咱们想要的搜索结果。在这里,咱们就不追根究底其底层实现原理了,如今咱们来看看在MySQL中如何建立并使用全文索引。性能优化

在MySQL中,建立全文索引相对比较简单。例如,咱们有一个文章表(article),其中有主键ID(id)、文章标题(title)、文章内容(content)三个字段。如今咱们但愿可以在title和content两个列上建立全文索引,article表及全文索引的建立SQL语句以下:网络

--建立article表并发

CREATE TABLE article (
    id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
    title VARCHAR(200),
    content TEXT,
    FULLTEXT (title, content) --在title和content列上建立全文索引
);

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

--给现有的article表的title和content字段建立全文索引 --索引名称为fulltext_article 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技术来处理中文。本站将会在后续文章中对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

相关文章
相关标签/搜索