【MySQL】提高篇—索引与性能优化:如何创建与管理索引

为了提高查询效率,数据库提供了索引的功能。索引可以看作是数据库表的“目录”,它允许数据库管理系统快速定位到所需的数据行,而无需扫描整个表。

通过合理地创建和管理索引,可以显著提升数据检索的速度和效率。

在实际应用中,索引的创建和管理非常重要。例如,在一个电商平台中,用户可能会根据产品名称、价格、类别等进行搜索。

如果没有索引,数据库在查找数据时可能需要遍历整个表,这会导致查询响应时间变长,从而影响用户体验。

因此,合理地使用索引能够提升系统的整体性能。

1. 创建索引的基本概念

创建索引的基本语法如下:

CREATE INDEX index_name ON table_name(column_name);
  • index_name:索引的名称。

  • table_name:要创建索引的表名。

  • column_name:要创建索引的列名。

2. 创建单列索引

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

示例:创建单列索引

假设我们有一个 products 表,我们将对 product_name 列创建单列索引。

-- 创建 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
);-- 插入示例数据
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');-- 创建单列索引
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';

3. 创建复合索引

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

示例:创建复合索引

我们将对 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;

4. 创建全文索引

全文索引主要用于对文本数据进行快速检索,适用于需要进行复杂文本搜索的场景。

示例:创建全文索引

我们将对 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');

5. 管理索引

在数据库使用过程中,索引的管理同样重要。我们需要定期检查和维护索引,以确保其性能。

5.1 查看索引

要查看某个表的所有索引,可以使用以下查询:

-- 查看 products 表的所有索引
SHOW INDEX FROM products;

解释

  • SHOW INDEX FROM products:列出 products 表的所有索引信息,包括索引名称、列、唯一性等。

5.2 删除索引

如果某个索引不再需要,或者影响了性能,可以将其删除。

-- 删除单列索引
DROP INDEX idx_product_name ON products;-- 删除复合索引
DROP INDEX idx_category_price ON products;-- 删除全文索引
DROP INDEX idx_description ON products;

解释

  • DROP INDEX idx_product_name ON products:删除名为 idx_product_name 的索引。

  • DROP INDEX idx_category_price ON products:删除名为 idx_category_price 的复合索引。

  • DROP INDEX idx_description ON products:删除名为 idx_description 的全文索引。

6. 索引的优缺点

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

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

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

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

7. 总结

索引在实际应用中非常重要,可以显著提高数据库的查询性能,更高效地处理和分析数据。合理地创建和管理索引是数据库优化的关键之一。

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

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

相关文章

自动化抖音点赞取消脚本批量处理

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

centos7 nginx优化

优化nginx进程个数的策略 在高并发、高访问量的web服务场景&#xff0c;需要事先启动好更多的nginx进程&#xff0c;以保证快速响应并处理大量并发用户的请求。worker_processes 1;一般调整到与CPU的颗数相同查看LInux可查看CPU个数及总核数grep processor /proc/cpuinfo|wc …

手机摄影入门

感觉会摄影的人是能够从生活中发现美的人。 我不太会拍照&#xff0c;觉得拍好的照片比较浪费时间&#xff0c;而且缺乏审美也缺乏技巧&#xff0c;所以拍照的时候总是拍不好。但有时候还是需要拍一些好看的照片的。 心态和审美可能需要比较长时间提升&#xff0c;但一些基础…

在不支持AVX的linux上使用PaddleOCR

背景 公司的虚拟机CPU居然不支持avx, 默认的paddlepaddle的cpu版本又需要有支持avx才行,还想用PaddleOCR有啥办法呢? 是否支持avx lscpu | grep avx 支持avx的话,会显示相关信息 如果不支持的话,python运行时导入paddle会报错 怎么办呢 方案一 找公司it,看看虚拟机为什么…

重学SpringBoot3-Spring WebFlux之HttpHandler和HttpServer

更多SpringBoot3内容请关注我的专栏&#xff1a;《SpringBoot3》 期待您的点赞&#x1f44d;收藏⭐评论✍ 重学SpringBoot3-Spring WebFlux之HttpHandler和HttpServer 1. 什么是响应式编程&#xff1f;2. Project Reactor 概述3. HttpHandler概述3.1 HttpHandler是什么3.2 Http…

有什么牌子的学生台灯性价比高?五款性价比高的学生用台灯

最近不少朋友都在问我&#xff0c;有什么牌子的学生台灯性价比高&#xff1f;说实话&#xff0c;这还真不是个容易回答的问题。市面上的台灯品种琳琅满目&#xff0c;价格从几十到上千都有&#xff0c;功能也是五花八门。选择一款适合自己的护眼台灯&#xff0c;确实需要好好琢…

深度学习中的迁移学习:优化训练流程与提高模型性能的策略,预训练模型、微调 (Fine-tuning)、特征提取

1024程序员节 | 征文 深度学习中的迁移学习&#xff1a;优化训练流程与提高模型性能的策略 目录 &#x1f3d7;️ 预训练模型&#xff1a;减少训练时间并提高准确性&#x1f504; 微调 (Fine-tuning)&#xff1a;适应新任务的有效方法&#x1f9e9; 特征提取&#xff1a;快速…

Flink 1.18安装 及配置 postgres12 同步到mysql5.7(Flink sql 方式)

文章目录 1、参考2、flink 常见部署模式组合3、Standalone 安装3.1 单节点安装3.2 问题13.3 修改ui 端口3.4 使用ip访问 4 flink sql postgres --->mysql4.1 配置postgres 124.2 新建用户并赋权4.3. 发布表4.4 Flink sql4.5 Could not find any factory for identifier post…

深度学习到底是怎么实现训练模型的(以医学图像分割为例

本文主要讲解的主要不是深度学习训练模型过程中的数学步骤&#xff0c;不是讲&#xff1a; 输入——前向传播——反向传播——输出&#xff0c;特征提取&#xff0c;特征融合等等过程。而是对于小白或者门外汉来说&#xff0c;知道模型怎么处理的&#xff0c;在用些什么东西&am…

推荐几个好用的配色网站

1.ColorSpace 地址&#xff1a;ColorSpace - Color Palettes Generator and Color Gradient Tool Color Space 是款功能强大的渐变色在线生成器&#xff0c;支持单色、双色&#xff0c;甚至三色渐变。 进入首页&#xff0c;输入一个颜色&#xff0c;点击 GENERATE&#xff08…

从一个简单的计算问题,看国内几个大语言模型推理逻辑能力

引言 首先&#xff0c;来看问题&#xff1a; 123456*987654等于多少&#xff0c;给出你计算的过程。 从openai推出chatgpt以来&#xff0c;大模型发展的很快&#xff0c;笔者也经常使用免费的大语言模型辅助进行文档编写和编码工作。大模型推出时间也好久了&#xff0c;笔者想…

autMan框架的定时推送功能学习

一、定时推送功能简介 “定时推送”位于“系统管理”目录 主要有两个使用方向&#xff1a; 一是定时向某人或某群发送信息。 二是定时运行某指令&#xff0c;就是机器人给自己发指令&#xff0c;让自己运行此指令。 二、定时推送设置 定时&#xff1a;cron表达式&#xff0c;…

Java 21新特性概述

Java 21于2023年9月19日发布&#xff0c;这是一个LTS&#xff08;长期支持&#xff09;版本&#xff0c;到此为止&#xff0c;目前有Java 8、Java 11、Java 17和Java 21这四个LTS版本。 Java 21此次推出了15个新特性&#xff0c;本节就介绍其中重要的几个特性&#xff1a; JEP…

Ubuntu20.04安装ROS2教程

Ubuntu20.04安装ROS2教程 ROS 2 安装指南支持的ROS 2 版本设置语言环境&#xff08;Set locale&#xff09;设置源&#xff08;Setup Sources&#xff09;设置密钥安装 ROS 2 包&#xff08;Install ROS 2 packages&#xff09;环境设置&#xff08;Environment setup&#xff…

java--反射(reflection)

一、反射机制 Java Reflection &#xff08;1&#xff09;反射机制允许程序在执行期借助 Reflection API 取得任何类的内部信息&#xff08;比如成员变量、构造器、成员方法等等&#xff09;&#xff0c;并能操作对象的属性及方法。反射在设计模式和框架底层都会用到。&#x…

时间序列预测(九)——门控循环单元网络(GRU)

目录 一、GRU结构 二、GRU核心思想 1、更新门&#xff08;Update Gate&#xff09;&#xff1a;决定了当前时刻隐藏状态中旧状态和新候选状态的混合比例。 2、重置门&#xff08;Reset Gate&#xff09;&#xff1a;用于控制前一时刻隐藏状态对当前候选隐藏状态的影响程度。…

Java项目-基于springboot框架的智慧外贸系统项目实战(附源码+文档)

作者&#xff1a;计算机学长阿伟 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、ElementUI等&#xff0c;“文末源码”。 开发运行环境 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBoot、Vue、Mybaits Plus、ELementUI工具&#xff1a;IDEA/…

小新学习K8s第一天之K8s基础概念

目录 一、Kubernetes&#xff08;K8s&#xff09;概述 1.1、什么是K8s 1.2、K8s的作用 1.3、K8s的功能 二、K8s的特性 2.1、弹性伸缩 2.2、自我修复 2.3、服务发现和负载均衡 2.4、自动发布&#xff08;默认滚动发布模式&#xff09;和回滚 2.5、集中化配置管理和密钥…

高效改进!防止DataX从HDFS导入关系型数据库丢数据

高效改进&#xff01;防止DataX从HDFS导入关系型数据库丢数据 针对DataX在从HDFS导入数据到关系型数据库过程中的数据丢失问题&#xff0c;优化了分片处理代码。改动包括将之前单一分片处理逻辑重构为循环处理所有分片&#xff0c;确保了每个分片数据都得到全面读取和传输&…

Python 实现 excel 数据过滤

一、场景分析 假设有如下一份 excel 数据 shop.xlsx, 写一段 python 程序&#xff0c;实现对于车牌的分组数据过滤。 并以车牌为文件名&#xff0c;把店名输出到 车牌.txt 文件中。 比如 闽A.txt 文件内容为&#xff1a; 小林书店福州店1 小林书店福州店2 二、依赖安装 程序依…