当前位置: 首页 > article >正文

【MySQL | 第八篇】索引的使用

目录一、索引的使用规则1.最左前缀法则2.范围查询3.索引的失效情况3.1索引列运算3.2字符串不加引号3.3模糊查询3.4or连接的条件3.5数据分布影响4.SQL提示5.覆盖索引⭐⭐⭐⭐⭐6.前缀索引7.单列索引与联合索引二、索引的涉及原则一、索引的使用规则1.最左前缀法则如果索引了多列(联合索引)要遵守最左前缀法则。最左前缀法则指的是查询从索引的最左列开始并且不跳过索引中的列。如果跳跃某一列索引将部分失效(后面的字段索引失效)。联合索引带的字段explain select * from tb user where profession 软件工程 and age 31 and status 0; explain select * from tb_user where profession 软件工程 and age 31; explain select * from tb_user where profession 软件工程; explain select * from tb_user where age 31 and status 0; explain select * from tb_user where status 0;根据最左前缀法则从索引的最左列profession开始后面紧接着的是age、status如果将profession字段去掉直接按age、status或只根据status查询那么该索引就会失效。2.范围查询联合索引中出现范围查询()范围查询右侧的列索引失效。explain select * from tb_user where profession 软件工程 and age 30 and status0; explain select * from tb_user where profession 软件工程 and age 30 and status 0;第一个sql语句出现了范围查询语句因此尽管满足最左前缀法则依然会使右侧的列索引失效。因此在使用复合索引时如果业务允许的情况下尽量使用来进行判断。3.索引的失效情况3.1索引列运算不要在索引列上进行运算操作索引将失效。3.2字符串不加引号字符串类型字段使用时不加引号索引将失效。3.3模糊查询如果仅仅是尾部模糊匹配索引不会失效。如果是头部模糊匹配索引失效。尾部模糊匹配头部模糊匹配3.4or连接的条件用or分割开的条件如果or前的条件中的列有索引而后面的列中没有索引那么涉及的索引都不会使用。也就是如果要使用索引就要求使用or连接的前面以及后面涉及到的列必须都有索引。3.5数据分布影响如果MySQL评估使用索引比全表更慢则不使用索引。4.SQL提示SQL提示是优化数据库的一个重要手段简单来说就是在SQL语句中加入一些人为的提示来达到优化操作的目的。use index():explain select * from tb_user use index(idx_user_pro) where profession 软件工程;ignore index():explain select * from tb_user ignore index(idx_user_pro) where profession 软件工程;force index():explain select * from tb_user force index(idx_user_pro) where profession 软件工程;5.覆盖索引⭐⭐⭐⭐⭐尽量使用覆盖索引查询使用了索引并且需要返回的列在该索引中已经全部能够找到减少select *。using index condition查找使用了索引但是name字段需要回表查询数据。using whereusing indx查找使用了索引但是需要的数据都在索引列中能找到所以不需要回表查询数据。6.前缀索引当字段类型为字符串(varchartext等)时有时候需要索引很长的字符串这会让索引变得很大查询时浪费大量的磁盘IO影响查询效率。此时可以只将字符串的一部分前缀建立索引这样可以大大节约索引空间从而提高索引效率。语法CREATE INDEX idx_xxxx ON 表名(column(n));提取column字段的前n个字符作为前缀索引。前缀长度可以根据索引的选择性来决定而选择性是指不重复的索引值(基数)和数据表的记录总数的比值索引选择性越高则查询效率越高唯一索引的选择性是1这是最好的索引选择性性能也是最好的。select count(distinct email) / count(*) from tb_user; select count(distinct substring(email, 1, 5)) / count(*) from tb_user;7.单列索引与联合索引在业务场景中如果存在多个查询条件考虑针对于查询字段建立索引时建议建立联合索引而非单列索引。多条件联合查询时MySQL优化器会评估哪个字段的索引效率更好会选择这个效率更高的索引来完成本次查询而不会同时使用两个因此此次查询还是涉及了回表查询。创建联合索引时索引字段的顺序是有要求的如果我们要查询数据并且要求用到这个索引时必须满足最左前缀原则。二、索引的涉及原则1.针对于数据量较大且查询比较频繁的表建立索引。2. 针对于常作为查询条件(where)、排序(order by)、分组(group by)操作的字段建立索引。3. 尽量选择区分度高的列作为索引尽量建立唯一索引区分度越高使用索引的效率越高。4.如果是字符串类型的字段字段的长度较长可以针对于字段的特点建立前缀索引。5.尽量使用联合索引减少单列索引查询时联合索引很多时候可以覆盖索引节省存储空间避免回表提高查询效率。6.要控制索引的数量索引并不是多多益善索引越多维护索引结构的代价也就越大会影响增删改的效率。7. 如果索引列不能存储NULL值请在创建表时使用NOT NULL约束它。当优化器知道每列是否包含NULL值时它可以更好地确定哪个索引最有效地用于查询。

相关文章:

【MySQL | 第八篇】索引的使用

目录 一、索引的使用规则 1.最左前缀法则 2.范围查询 3.索引的失效情况 3.1索引列运算 3.2字符串不加引号 3.3模糊查询 3.4or连接的条件 3.5数据分布影响 4.SQL提示 5.覆盖索引⭐⭐⭐⭐⭐ 6.前缀索引 7.单列索引与联合索引 二、索引的涉及原则 一、索引的使用规则…...

Wand-Enhancer:免费解锁WeMod高级功能的完整指南

Wand-Enhancer:免费解锁WeMod高级功能的完整指南 【免费下载链接】Wand-Enhancer Advanced UX and interoperability extension for Wand (WeMod) app 项目地址: https://gitcode.com/gh_mirrors/we/Wand-Enhancer 你是否厌倦了WeMod游戏助手的付费限制&…...

别再被5V电源坑了!ESP32-CAM搭配CH340烧录与运行的全流程避坑指南

ESP32-CAM电源与烧录终极指南:从硬件连接到稳定运行 刚拿到ESP32-CAM开发板时,那种跃跃欲试的兴奋感很快会被一连串的硬件问题浇灭——电源接3.3V无法启动、CH340接线错误导致烧录失败、IO0引脚状态不对让设备"装死"。这些问题困扰着每一位刚接…...

从短期利率到波动率:手把手用Python复现CIR模型,搞定金融时间序列模拟

从短期利率到波动率:手把手用Python复现CIR模型,搞定金融时间序列模拟 金融市场的波动性和利率变化常常让分析师们头疼不已。想象一下,你手头有一组历史利率数据,老板突然要求你预测未来半年可能出现的极端情景——这可不是靠直觉…...

Go 语言从入门到进阶 | 第 16 章:反射(Reflection)

系列:Go 语言从入门到进阶 作者:耿雨飞 适用版本:go v1.26.2 前置条件 在开始本章学习之前,请确保: 已完成第 6 章(接口与多态)的学习,理解接口的动态类型和动态值 已完成第 4 章(复合数据类型)的学习,熟悉结构体和标签语法 已获取 Go 1.26.2 源码树(go-go1.26.2 …...

用STM32F103和VS1053B手搓一个MP3播放器:从SD卡读取到OLED显示的完整流程

用STM32F103和VS1053B打造高保真MP3播放器:从硬件搭建到软件优化的全流程解析 在嵌入式音频开发领域,DIY一个具备完整功能的MP3播放器始终是检验开发者系统设计能力的经典项目。本文将基于STM32F103微控制器与VS1053B解码芯片的组合,深入剖析…...

Claude Code 十大必装 MCP 排行榜(2026年最新版)

🏆 Claude Code 十大必装 MCP 排行榜(2026年最新版) 作为一名重度使用 Claude Code 的开发者,我踩过不少坑,也发现了许多能极大提升开发效率的 MCP。今天就把我心目中最值得安装的10个 MCP 整理出来,附带详…...

Synopsys AXI VIP实战:除了outstanding检查,回调机制还能帮你做哪些事?

Synopsys AXI VIP回调机制深度实战:解锁验证效率的五大高阶技巧 AXI总线作为现代SoC设计的核心互联标准,其验证复杂度随着系统规模呈指数级增长。Synopsys验证IP(VIP)提供的回调机制,就像给验证工程师配备了一把瑞士军…...

如何搭建个人游戏串流服务器:Sunshine完整指南

如何搭建个人游戏串流服务器:Sunshine完整指南 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款开源的游戏串流服务器,能够将高性能电脑上的游…...

实战解析:在华为云Stack(HCS 6.5)中如何为Oracle RAC规划BMS裸金属与高性能云硬盘

华为云Stack 6.5环境下Oracle RAC的裸金属与存储架构设计指南 当企业将Oracle RAC这类关键数据库迁移到私有云环境时,基础设施的规划直接决定了业务系统的稳定性和性能表现。华为云Stack 6.5(HCS)作为成熟的私有云解决方案,其BMS裸…...

告别双系统折腾!用Python工具rosbags一键搞定ROS1/ROS2的bag文件互转

告别双系统折腾!用Python工具rosbags一键搞定ROS1/ROS2的bag文件互转 在机器人开发领域,数据记录与回放是调试和验证算法的重要环节。ROS1和ROS2作为机器人操作系统的主流版本,各自采用不同的数据存储格式,这给开发者带来了不小的…...

海外短剧APP开发,从0到1:硬刚谷歌商店合规,打通海外多币种支付!

短剧出海“掘金”正当时,但很多团队在第一步就卡住了:APP 被谷歌商店拒审、支付掉单严重、封号风险高。相比 H5 的灵活,APP 虽然周期长,但 留存和 LTV 更高,是建立品牌壁垒的必选项。 今天就聊聊如何开发一款符合谷歌…...

番茄小说下载器:构建个人数字图书馆的高效解决方案

番茄小说下载器:构建个人数字图书馆的高效解决方案 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 还在为网络不稳定无法畅快阅读而烦恼吗?这款基于Rus…...

大语言模型偏见量化实战(R语言统计框架全公开)

更多请点击: https://intelliparadigm.com 第一章:大语言模型偏见量化的基本概念与R语言生态定位 大语言模型(LLM)偏见量化是指通过可复现的统计指标与实验范式,系统性地测量模型在性别、种族、地域、职业等维度上输出…...

【VS Code MCP插件生态架构白皮书】:20年IDE架构师亲授从零搭建高兼容、可扩展、易维护的MCP服务层(含4层抽象设计图+3大协议适配范式)

更多请点击: https://intelliparadigm.com 第一章:VS Code MCP插件生态搭建手册 MCP 协议与 VS Code 集成原理 MCP(Model Context Protocol)是面向大模型工具调用的开放协议,VS Code 通过官方语言服务器协议&#xf…...

如何实现ComfyUI-Manager离线部署:3种本地安装方案详解

如何实现ComfyUI-Manager离线部署:3种本地安装方案详解 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various cust…...

数字线程:数字孪生的“中枢神经”,如何驱动产业智能升级?

数字线程:数字孪生的“中枢神经”,如何驱动产业智能升级? 引言 (配图建议:一张对比图,左侧是分散、断裂的传统数据流,右侧是通过一条光带“数字线程”串联起的全生命周期数据闭环。)…...

深入Gold-YOLO的GD机制:看华为如何用‘聚集-分发’解决YOLO系列的老大难问题

深入解析Gold-YOLO的GD机制:重新定义多尺度特征融合范式 当目标检测领域还在为FPN和PANet的信息传输瓶颈争论不休时,华为诺亚方舟实验室在2023年NeurIPS会议上抛出了一枚技术"深水炸弹"——Gold-YOLO。这个以"聚集-分发"&#xff08…...

上下文多臂老虎机在LLM查询优化中的应用与实现

1. 上下文多臂老虎机在LLM查询优化中的核心原理上下文多臂老虎机(Contextual Bandits)是强化学习中的一个重要分支,它通过结合上下文信息来优化决策过程。在自然语言处理领域,这种方法被广泛应用于查询优化和响应生成。其核心原理…...

如何用AI插件让Zotero文献管理效率提升300%?探索GPT智能分析新范式

如何用AI插件让Zotero文献管理效率提升300%?探索GPT智能分析新范式 【免费下载链接】zotero-gpt GPT Meet Zotero. 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-gpt 传统文献管理工具在面对海量学术论文时,研究者常常陷入信息过载的困境…...

ccswitch-terminal:一键切换终端上下文,提升开发效率的自动化利器

1. 项目概述与核心价值最近在折腾一些自动化脚本和工具链,发现一个挺有意思的场景:当你在终端里切换不同的工作环境时,比如从Python虚拟环境切换到Node.js项目,或者从本地开发环境切换到容器内部,经常需要手动执行一系…...

WeChatExporter:三步永久备份微信聊天记录,告别数据丢失烦恼

WeChatExporter:三步永久备份微信聊天记录,告别数据丢失烦恼 【免费下载链接】WeChatExporter 一个可以快速导出、查看你的微信聊天记录的工具 项目地址: https://gitcode.com/gh_mirrors/wec/WeChatExporter 你是否曾因手机丢失、系统升级或误删…...

Full Page Screen Capture:彻底解决长网页截图难题的终极工具

Full Page Screen Capture:彻底解决长网页截图难题的终极工具 【免费下载链接】full-page-screen-capture-chrome-extension One-click full page screen captures in Google Chrome 项目地址: https://gitcode.com/gh_mirrors/fu/full-page-screen-capture-chrom…...

AI驱动的项目开发全流程自动化:扣子实战指南

引言传统软件开发流程包含需求、设计、开发、测试、发布等环节,每个环节都依赖人工协调,效率低、成本高、质量难以保证。AI大模型正在改变这一切。当AI具备了需求理解、代码生成、测试编写、自动部署等能力时,我们可以构建一条从需求到上线的…...

LangChain Memory

一、LangChain Memory 核心概念详解LangChain 的 Memory(记忆系统) 是让 Agent / 聊天机器人实现多轮对话、上下文理解、经验复用的核心模块,它解决了大模型「单轮对话、上下文窗口有限、跨会话失忆」的三大核心缺陷。1. 什么是 LangChain Me…...

【RK3568】dummy.c

阶段1:主要是注册 platform_driver,创建设备static struct platform_driver snd_dummy_driver {.probe snd_dummy_probe,.remove snd_dummy_remove,.driver {.name SND_DUMMY_DRIVER,.pm SND_DUMMY_PM_OPS,}, };module_init( alsa_card_dummy_i…...

3分钟掌握Xenos:Windows平台最全面的DLL注入解决方案

3分钟掌握Xenos:Windows平台最全面的DLL注入解决方案 【免费下载链接】Xenos Windows dll injector 项目地址: https://gitcode.com/gh_mirrors/xe/Xenos 你是否曾想在Windows系统中为其他程序添加功能或进行调试,却发现传统的DLL注入方法既复杂又…...

全自动的智能鱼缸推荐

养鱼本是件陶冶情操的事,可传统养鱼方式却状况百出,让不少人头疼不已。数据显示,新手死鱼率超60%,37%鱼友因维护麻烦放弃,出差旅游时也无法照顾。传统养鱼的痛点新手养鱼,死鱼率高是大问题。因为缺乏科学水…...

Sunshine游戏串流终极指南:如何打造你的个人云游戏服务器

Sunshine游戏串流终极指南:如何打造你的个人云游戏服务器 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一个强大的自托管游戏串流服务器解决方案&#xff…...

RimSort终极指南:3分钟搞定环世界MOD管理,告别加载顺序混乱

RimSort终极指南:3分钟搞定环世界MOD管理,告别加载顺序混乱 【免费下载链接】RimSort RimSort is an open source mod manager for the video game RimWorld. There is support for Linux, Mac, and Windows, built from the ground up to be a reliable…...