索引是存储引擎用于快速找到记录的一种数据结构。
索引优化是对查询性能优化最有效的手段。索引能够轻易将查询性能提高几个数量级。
索引可以包含一个或多个列的值。如果索引包含多个列,那么列的顺序也十分重要,因为mysql只能高效地使用索引的最左前缀列。
全文索引了解一下即可:
https://blog.csdn.net/mrzhouxiaofei/article/details/79940958
1、创建表时创建全文索引
create table fulltext_test (
id int(11) NOT NULL AUTO_INCREMENT,
content text NOT NULL,
tag varchar(255),
PRIMARY KEY (id),
FULLTEXT KEY content_tag_fulltext(content,tag) // 创建联合全文索引列
) ENGINE=MyISAM DEFAULT CHARSET=utf8;
2、在已存在的表上创建全文索引
create fulltext index content_tag_fulltext
on fulltext_test(content,tag);
使用全文索引
和常用的模糊匹配使用 like + % 不同,全文索引有自己的语法格式,使用 match 和 against 关键字,比如
select * from fulltext_test
where match(content,tag) against('xxx xxx');
https://blog.csdn.net/weixin_39420024/article/details/80040549
何时不使用索引:
1、表记录太少;
2、经常插入、删除、修改的表要减少索引;
。。。
索引何时失效
1、组合索引未使用最左前缀,例如组合索引(A,B),where B=b不会使用索引;
2、like未使用最左前缀,where A like '%China';
3、or会使索引失效。如果查询字段相同,也可以使用索引。例如where A=a1 or A=a2(生效),where A=a or B=b(失效)