mysql索引 -- 全文索引介绍(如何创建,使用),explain关键字

目录

全文索引

引入

介绍

创建

使用

表数据

简单搜索

explain关键字

使用全文索引


mysql索引结构详细介绍 -- mysql索引 -- 索引的硬件理解(磁盘,磁盘与系统),软件理解(mysql,与系统io,buffer pool),索引结构介绍和理解(page内部,page之间,为什么是b+树)-CSDN博客

全文索引

引入

如果需要对文章进行检索

  • 假设它有一列body字段(text类型),可以容纳上万个字符
  • 而我们想要找到body中某一行中的一些字段,就需要使用全文索引

之前介绍的b+树构成的索引,都是想要找到某一列/某几列的数据,而不是这里想要的一列中的一部分

介绍

是一种特殊类型的索引,主要用于加速对大文本数据的搜索

  • 适合实现搜索引擎功能

目前,只有MyISAM存储引擎支持全文索引,且只支持英文的

  • 特点:支持高并发读

创建

语法 -- FULLTEXT(列名)

  • 默认以列名为索引名称

使用

表数据

sql 复制代码
CREATE 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在列内部进行模糊匹配:

sql 复制代码
select * 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 -- 指明使用的是哪一个全文索引(索引名)
相关推荐
此刻你15 小时前
常用的 SQL 语句
数据库·sql·oracle
それども15 小时前
分库分表的事务问题 - 怎么实现事务
java·数据库·mysql
·云扬·16 小时前
MySQL Binlog 配置指南与核心作用解析
数据库·mysql·adb
天空属于哈夫克316 小时前
Java 版:利用外部群 API 实现自动“技术开课”倒计时提醒
数据库·python·mysql
luoluoal16 小时前
基于深度学习的web端多格式纠错系统(源码+文档)
python·mysql·django·毕业设计·源码
eWidget16 小时前
随机森林原理:集成学习思想 —— Java 实现多棵决策树投票机制
java·数据库·随机森林·集成学习·金仓数据库
Traced back16 小时前
SQL Server 核心语法+进阶知识点大全(小白版)
数据库·sqlserver
资深web全栈开发16 小时前
PostgreSQL枚举还是字符串:ENUM vs VARCHAR + CHECK 的权衡
数据库·postgresql
凯子坚持 c17 小时前
C++基于微服务脚手架的视频点播系统---客户端(4)
数据库·c++·微服务
OceanBase数据库官方博客17 小时前
OceanBase场景解码系列三|OB Cloud 如何稳定支撑中企出海实现数 10 倍的高速增长?
数据库·oceanbase·分布式数据库