【MySQL】提高篇—索引与性能优化:索引的概念与类型(单列索引、复合索引、全文索引)

在关系数据库中,当表中的数据量增大时,查询性能可能会显著下降。为了提高数据检索的效率,数据库系统提供了索引的概念。

索引类似于书籍的目录,可以快速定位到特定的数据行,从而加快查询速度。

索引的使用在实际应用中至关重要,尤其是在处理大量数据时。

比如,在一个电商平台中,用户可能会根据产品名称、价格、类别等进行搜索。 如果没有索引,数据库在查找数据时可能需要扫描整个表,这会导致查询变得非常缓慢。 通过创建适当的索引,可以显著提高查询效率。

1. 索引的基本概念

索引是数据库表中一个或多个列的值的集合,允许数据库快速查找和访问数据。索引的类型主要包括:

  • 单列索引:对单个列创建的索引。

  • 复合索引:对多个列组合创建的索引。

  • 全文索引:专门用于快速检索文本数据中的关键词。

2. 创建示例表

我们将创建一个示例表 products,用于存储产品信息。

-- 创建 products 表
CREATE TABLE products (product_id INT PRIMARY KEY AUTO_INCREMENT,product_name VARCHAR(100) NOT NULL,category VARCHAR(50),price DECIMAL(10, 2),description TEXT
);

3. 插入示例数据

接下来,我们插入一些示例数据到 products 表中。

-- 插入产品数据
INSERT INTO products (product_name, category, price, description) VALUES
('Laptop', 'Electronics', 1000.00, 'High performance laptop'),
('Mouse', 'Electronics', 25.00, 'Wireless mouse'),
('Keyboard', 'Electronics', 50.00, 'Mechanical keyboard'),
('Monitor', 'Electronics', 300.00, '4K monitor'),
('Tablet', 'Electronics', 400.00, '10-inch tablet'),
('Chair', 'Furniture', 150.00, 'Ergonomic office chair'),
('Desk', 'Furniture', 200.00, 'Wooden desk');

4. 单列索引

单列索引是对表中的单个列创建的索引,适用于频繁查询的列。它可以加速基于该列的查询操作。

示例:创建单列索引

我们将对 product_name 列创建单列索引。

-- 创建单列索引
CREATE INDEX idx_product_name ON products(product_name);

解释

  • CREATE INDEX idx_product_name:创建一个名为 idx_product_name 的索引。

  • ON products(product_name):指定索引应用于 products 表的 product_name 列。

查询示例

使用索引后,查询速度会加快:

-- 查询产品名称为 'Laptop' 的产品
SELECT * FROM products WHERE product_name = 'Laptop';

解释

  • 由于我们在 product_name 列上创建了索引,数据库可以快速定位到对应的行,而不需要扫描整个表。

5. 复合索引

复合索引是对多个列组合创建的索引,适用于需要同时基于多个列进行查询的场景。

示例:创建复合索引

我们将对 categoryprice 列创建复合索引。

-- 创建复合索引
CREATE INDEX idx_category_price ON products(category, price);

解释

  • CREATE INDEX idx_category_price:创建一个名为 idx_category_price 的复合索引。

  • ON products(category, price):指定索引应用于 products 表的 categoryprice 列。

查询示例

使用复合索引后,基于这两个列的查询速度会加快:

-- 查询价格低于 500 的电子产品
SELECT * FROM products WHERE category = 'Electronics' AND price < 500;

解释

  • 由于我们在 categoryprice 列上创建了复合索引,数据库可以快速定位到符合条件的行。

6. 全文索引

全文索引主要用于对文本数据进行快速检索,适用于需要进行复杂文本搜索的场景。它通常用于长文本字段,例如 description

示例:创建全文索引

我们将对 description 列创建全文索引。

-- 创建全文索引
CREATE FULLTEXT INDEX idx_description ON products(description);

解释

  • CREATE FULLTEXT INDEX idx_description:创建一个名为 idx_description 的全文索引。

  • ON products(description):指定索引应用于 products 表的 description 列。

查询示例

使用全文索引后,可以进行复杂的文本搜索:

-- 查询描述中包含 'laptop' 的产品
SELECT * FROM products WHERE MATCH(description) AGAINST('laptop');

解释

  • MATCH(description) AGAINST('laptop'):使用全文索引对 description 列进行搜索,查找包含关键词 'laptop' 的记录。

7. 索引的优缺点

优点:
  • 提高查询速度:索引可以显著加快数据检索的速度,尤其是在大数据量的情况下。

  • 优化排序和分组:索引可以加速 ORDER BY 和 GROUP BY 操作。

缺点:
  • 增加存储空间:索引需要额外的存储空间。

  • 影响插入和更新性能:每次对表进行插入、更新或删除操作时,索引也需要更新,这可能会导致性能下降。

8. 总结

通过本节的示例,您应该能够理解索引的基本概念及其类型:

  • 单列索引:对单个列创建的索引,适用于频繁查询的列。

  • 复合索引:对多个列组合创建的索引,适用于需要同时基于多个列进行查询的场景。

  • 全文索引:专门用于快速检索文本数据中的关键词,适用于长文本字段。

索引在实际应用中非常重要,可以显著提高数据库的查询性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/56682.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot034在线商城系统设计与开发-代码(论文+源码)_kaic

毕 业 设 计&#xff08;论 文&#xff09; 题目&#xff1a;ONLY在线商城系统设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本ONLY在线商城系统…

Dubbo 序列化方式

Hession 这是dubbo的默认序列化协议&#xff0c;是一种二进制协议&#xff0c;他的特点是序列化的速度比较快&#xff0c;并且序列化的数据体积比较小。Hession适合于大部分场景&#xff0c;因此被选为dubbo的默认序列化协议。 Json Json是一种基于文本的序列化方式&#xf…

python+Mosh网课笔记02

太久没写python代码了&#xff0c;学机器学习重新拾起python&#xff0c;笔记比较简陋。 参考&#xff1a;mosh的python教程 目录 一、控制流 二、函数functions 三、数据结构 list stack queue tuple swapping variables array sets dictionary 解包 一、控制流…

机械臂力控方法概述(一)

目录 1. MoveIt 适用范围 2. 力控制框架与 MoveIt 的区别 3. 力控方法 3.1 直接力控制 (Direct Force Control) 3.2 间接力控制 (Indirect Force Control) 3.2.1 柔顺控制 (Compliant Control) 3.2.2 阻抗控制 (Impedance Control) 3.2.3 导纳控制 (Admittance Control…

Wordpress—一个神奇的个人博客搭建框架

wordpress简介 在当今数字化的时代&#xff0c;拥有一个属于自己的个人博客&#xff0c;不仅可以记录生活点滴、分享专业知识&#xff0c;还能展示个人风采。而在众多的博客搭建框架中&#xff0c;Wordpress 以其强大的功能和灵活性脱颖而出。今天&#xff0c;就让我们一起深入…

【秋招笔试】10.13拼多多(已改编)秋招-三语言题解

🍭 大家好这里是 春秋招笔试突围,一起备战大厂笔试 💻 ACM金牌团队🏅️ | 多次AK大厂笔试 | 大厂实习经历 ✨ 本系列打算持续跟新 春秋招笔试题 👏 感谢大家的订阅➕ 和 喜欢💗 和 手里的小花花🌸 ✨ 笔试合集传送们 -> 🧷春秋招笔试合集 🍒 本专栏已收集…

大数据研究实训室建设方案

一、概述 本方案旨在提出一套全面的大数据研究实训室建设策略&#xff0c;旨在为学生打造一个集理论学习与实践操作于一体的高端教育环境。实训室将专注于培养学生在大数据处理、分析及应用领域的专业技能&#xff0c;通过先进的设施配置、科学的课程体系和实用的实训模式&…

红黑树的底层讲解

一、红黑树的介绍 红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在每个结点上增加一个存储位表示结点的颜色&#xff0c;可以是红&#xff08;red&#xff09;或黑&#xff08;black&#xff09;。通过对任何一条从根到叶子的路径上各个结点着色方式的限制&#xff0c;红…

FLINK SQL语法(1)

DDL Flink SQL DDL&#xff08;Data Definition Language&#xff09;是Flink SQL中用于定义和管理数据结构和数据库对象的语法。以下是对Flink SQL DDL的详细解析&#xff1a; 一、创建数据库&#xff08;CREATE DATABASE&#xff09; 语法&#xff1a;CREATE DATABASE [IF…

linux环境下的程序设计与git操作

目录 前言&#xff1a; 进度条小程序&#xff1a; 先介绍几个背景知识 代码实现 Git操作 总结 其他指令 前言&#xff1a; 本文将重点介绍1. linux下的程序设计&#xff0c;并使用linux下的几个函数接口。实现一个简单的小程序 2.本着开源精神&#xff0c;进行git操作。…

Vue详细入门(语法【三】)

今天滴的学习目标&#xff01;&#xff01;&#xff01; Vue组件是什么&#xff1f;组件的特性和优势Vue3计算属性Vue3监听属性 在前面Vue详细入门&#xff08;语法【一】——【二】&#xff09;当中我们学习了Vue有哪些指令&#xff0c;它的核心语法有哪些&#xff1f;今天我们…

在 javascript 中使用相邻参数作为函数的默认值

更多好文&#xff0c;欢迎关注公众号Geek技术前线 默认参数值在JavaScript中已经存在一段时间了。但其实可以将前面的相邻参数作为默认值本身。 JavaScript自ES2015以来就支持默认参数值&#xff0c;但我们可能不知道的是&#xff0c;我们可以将之前的相邻参数作为默认值 fun…

(AtCoder Beginner Contest 375) 题解(下)

一、题解 第 E 题 3 Team Division 一眼看像背包&#xff0c;观察数据范围&#xff0c;合法的总能力值 ≤ 500 \le 500 ≤500&#xff0c;那么我们可以设计一个背包DP&#xff1a; int dp[110][510][510]; //dp[i][j][k] 表示前 i 个人&#xff0c;分给第一组的能力值是 j&…

微服务架构 --- 使用Seata处理分布式事务

目录 一.Seata 是什么? 1.Seata的核心架构&#xff1a; 2. Seata的分布式事务处理流程&#xff1a; 二.Seata的基本使用&#xff1a; 1.环境准备&#xff1a; 2.引入依赖&#xff1a; 3.加入配置来使用Seata&#xff1a; &#xff08;1&#xff09;首先在nacos上添加一…

免费版视频压缩软件:让视频处理更便捷

现在不少人已经习惯通过视频来记录生活、传播信息和进行娱乐的重要方式。但是由于设备大家现在录制的文件都会比较大&#xff0c;这时候就比较需要一些缩小视频的工具了。今天我们一起来探讨视频压缩软件免费版来为我们带来的生动世界。 1.Foxit视频压缩大师 链接直达&#x…

ESP32移植Openharmony外设篇(1)MQ-2烟雾传感器

外设篇 实验箱介绍 旗舰版实验箱由2部分组成&#xff1a;鸿蒙外设模块&#xff08;支持同时8个工作&#xff09;、鸿蒙平板。 其中&#xff0c;鸿蒙平板默认采用RK3566方案。 OpenHarmony外设模块采用底板传感器拓展板方式&#xff0c;底板默认采用ESP32方案&#xff0c;也…

青少年编程能力等级测评CPA C++一级试卷(1)

青少年编程能力等级测评CPA C一级试卷&#xff08;1&#xff09; 一、单项选择题&#xff08;共20题&#xff0c;每题3.5分&#xff0c;共70分&#xff09; CP1_1_1&#xff0e;在C中&#xff0c;下列变量名正确的是&#xff08; &#xff09;。 A&#xff0e;$123 B&#…

网络通信与并发编程(三)粘包现象解决方案、socketserver实现并发

粘包现象解决方案、socketserver实现并发 文章目录 粘包现象解决方案、socketserver实现并发一、粘包现象解决方案1.发送数据大小2.发送数据信息 二、socketserver实现并发1.tcp版的socketserver并发2.udp版的socketserver并发 一、粘包现象解决方案 1.发送数据大小 有了上一…

Redis 的安装与部署(图文)

前言 Redis 暂不支持Windows 系统&#xff0c;官网上只能下载Linux 环境的安装包。但是启用WSL2 就可以在Windows 上运行Linux 二进制文件。[要使此方法工作&#xff0c;需要运行Windows 10 2004版及更高版本或Windows 11]。本文在CentOS Linux 系统上安装最新版Redis&#xf…

力扣10.18

1463. 摘樱桃 II 给你一个 rows x cols 的矩阵 grid 来表示一块樱桃地。 grid 中每个格子的数字表示你能获得的樱桃数目。 你有两个机器人帮你收集樱桃&#xff0c;机器人 1 从左上角格子 (0,0) 出发&#xff0c;机器人 2 从右上角格子 (0, cols-1) 出发。 请你按照如下规则…