MYSQL索引主要分为四类:主键索引,普通索引(聚合,非聚合),唯一索引,全文索引
全文索引,主要是针对对文件,文本的检索, 比如文章, 全文索引针对MyISAM有用。
索引的原理:利用二叉树(哈希表)对建立索引的相关列进行重排。
创建 :
CREATE TABLE articles (
id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY,
title VARCHAR(200),
body TEXT,
FULLTEXT (title,body)
)engine=myisam charset utf8;
INSERT INTO articles (title,body) VALUES
('MySQL Tutorial','DBMS stands for DataBase ...'),
('How To Use MySQL Well','After you went through a ...'),
('Optimizing MySQL','In this tutorial we will show ...'),
('1001 MySQL Tricks','1. Never run mysqld as root. 2. ...'),
('MySQL vs. YourSQL','In the following database comparison ...'),
('MySQL Security','When configured properly, MySQL ...');
如何使用全文索引:
错误用法:
select * from articles where body like ‘%mysql%’; 【不会使用到全文索引】
证明:
explain select * from articles where body like ‘%mysql%’\G
正确的用法:
select * from articles where match(title,body) against(‘database’); 【可以】
☞ 说明:
- 在mysql中fulltext 索引只针对 myisam生效
- mysql自己提供的fulltext针对英文生效->sphinx (coreseek) 技术处理中文
- 使用方法是 match(字段名..) against(‘关键字’)
- 全文索引一个 叫 停止词, 因为在一个文本中,创建索引是一个无穷大的数。对一些常用词和字符,就不会创建,这些词,称为停止词。
索引的查看:
desc 表名 【该方法的缺点是: 不能够显示索引名.】
show index(es) from 表名
show keys from 表名
建立索引的优先条件:a: 肯定在where条经常使用(频繁作为查询条件的列) b: 该字段的内容不是唯一的几个值(sex) c: 字段内容不是频繁变化.
索引的代价(缺点):1、占用磁盘空间;2、影响DML操作(update,insert,delete),使速度变慢。[每一次DML操作会使二叉树(索引列)进行重排]
使用索引的注意事项:
说明,如果表中有复合索引(索引作用在多列上), 此时我们注意:
1、 对于创建的多列索引,只要查询条件使用了最左边的列,索引一般就会被使用。
explain select * from dept where loc='aaa'\G 就不会使用到索引
2、对于使用like的查询,查询如果是 ‘%aaa’ 不会使用到索引 ‘aaa%’ 会使用到索引。
比如: explain select * from dept where dname like '%aaa'\G
不能使用索引,即,在like查询时,关键的 ‘关键字’ , 最前面,不能使用 % 或者 _这样的字符。 如果一定要前面有变化的值,则考虑使用 全文索引->sphinx.
3、如果条件中有or,即使其中有条件带索引也不会使用。换言之,就是要求使用的所有字段,都必须建立索引, 建议尽量避免使用or 关键字
select * from dept where dname=’xxx’ or loc=’xx’ or deptno=45
4、列类型是字符串,要在条件中将数据使用引号引用起来。否则不使用索引。(如果列是字符串类型,就一定要用 ‘’ 包括起来)。
5、如果mysql估计使用全表扫描要比使用索引快,则不使用索引。