目录
mysql索引结构详细介绍 -- mysql索引 -- 索引的硬件理解(磁盘,磁盘与系统),软件理解(mysql,与系统io,buffer pool),索引结构介绍和理解(page内部,page之间,为什么是b+树)-CSDN博客
全文索引
引入
如果需要对文章进行检索
- 假设它有一列body字段(text类型),可以容纳上万个字符
- 而我们想要找到body中某一行中的一些字段,就需要使用全文索引
之前介绍的b+树构成的索引,都是想要找到某一列/某几列的数据,而不是这里想要的一列中的一部分
介绍
是一种特殊类型的索引,主要用于加速对大文本数据的搜索
- 适合实现搜索引擎功能
目前,只有MyISAM存储引擎支持全文索引,且只支持英文的
- 特点:支持高并发读
创建
语法 -- FULLTEXT(列名)
- 默认以列名为索引名称
使用
表数据
sqlCREATE TABLE articles ( id INT UNSIGNED AUTO_INCREMENT NOT NULL PRIMARY KEY, title VARCHAR(200), body TEXT, FULLTEXT (title,body) )engine=MyISAM; 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 ...');
因为我们一般会先确定文章标题,然后再在文章内部查询
- 所以我们以(title,body)创建全文索引 -- FULLTEXT (title,body)
简单搜索
可以使用like在列内部进行模糊匹配:
sqlselect * from articles where body like '%database%';
- 这是简单搜索,并没有用到全文索引
- 普通搜索时不会自动使用全文索引
explain关键字
在sql语句前添加explain关键字,可以显示mysql会如何执行这条语句(执行计划):
select_type:查询类型
- simple:简单查询
- primary:主查询
type:连接类型,表明访问的效率
- all :全部遍历
- index:索引扫描
key:实际使用的索引
- null:没有使用
使用全文索引
语法 -- where + match(key值) against ('要查找的字符')
再次查看执行计划:
- type :fulltext -- 使用全文索引
- key :title -- 指明使用的是哪一个全文索引(索引名)