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

【SQL】什么是最左前缀原则/最左匹配原则

最左前缀原则(或最左匹配原则)是关系型数据库在使用复合索引时遵循的一条重要规则。该原则指的是,当查询条件使用复合索引时,查询优化器会首先使用索引的最左边的列,依次向右匹配,直到不再满足查询条件为止。

复合索引

复合索引(也称多列索引)是一个包含多个列的索引。例如:

CREATE INDEX idx_user ON Users (LastName, FirstName, Age);

这个复合索引包含了 LastNameFirstNameAge 三列。

最左前缀原则

在上述复合索引中,最左前缀原则的具体应用如下:

  1. 完整匹配最左列
    • 可以使用 LastName 进行查询。
    • 可以使用 LastNameFirstName 进行查询。
    • 可以使用 LastNameFirstNameAge 进行查询。
  2. 不能跳过列
    • 不能只使用 FirstName 进行查询,必须包含 LastName
    • 不能只使用 Age 进行查询,必须包含 LastNameFirstName

示例

假设有以下表结构和数据:

CREATE TABLE Users (UserID INT PRIMARY KEY,LastName VARCHAR(100),FirstName VARCHAR(100),Age INT
);CREATE INDEX idx_user ON Users (LastName, FirstName, Age);
匹配最左前缀的查询

这些查询可以利用复合索引:

-- 只使用 LastName
SELECT * FROM Users WHERE LastName = 'Smith';-- 使用 LastName 和 FirstName
SELECT * FROM Users WHERE LastName = 'Smith' AND FirstName = 'John';-- 使用 LastName, FirstName 和 Age
SELECT * FROM Users WHERE LastName = 'Smith' AND FirstName = 'John' AND Age = 30;
不匹配最左前缀的查询

这些查询无法完全利用复合索引:

-- 只使用 FirstName,不能利用索引
SELECT * FROM Users WHERE FirstName = 'John';-- 使用 FirstName 和 Age,不能利用索引
SELECT * FROM Users WHERE FirstName = 'John' AND Age = 30;-- 只使用 Age,不能利用索引
SELECT * FROM Users WHERE Age = 30;

总结

最左前缀原则在设计和使用复合索引时非常重要。它决定了查询能否有效地利用复合索引,从而影响查询性能。在创建复合索引时,必须根据实际查询的需求,将使用频率最高的列放在索引的最左边,以便最大限度地利用索引进行查询优化。

http://www.lryc.cn/news/393669.html

相关文章:

  • java项目配置logback日志
  • Python入门 2024/7/6
  • ChatGPT4深度解析:探索智能对话新境界
  • 触底加载的两种思路(以vue3前端和nodejs后端为例)
  • tobias实现支付宝支付
  • 【音视频 | RTSP】RTSP协议详解 及 抓包例子解析(详细而不赘述)
  • SQL Server 2022 中的 Tempdb 性能改进非常显著
  • C++ Lambda表达式第二篇, Lambda表达式
  • Linux系统的介绍和常用命令
  • IDEA安装IDE Eval Reset插件,30天自动续期,无限激活
  • 【C++】初步认识C++
  • 【Python数据分析与可视化】:使用【Matplotlib】实现销售数据的全面分析 ——【Matplotlib】数模学习
  • Docker加速器配置指南:提升镜像下载速度的秘诀 加速安装Mysql Redis ES
  • 32单片机,C语言与汇编联合编译的几种方式
  • 基于GWO-CNN-BiLSTM数据回归预测(多输入单输出)-灰狼优化算法优化CNN-BiLSTM
  • 自动控制:反馈控制
  • sqlite 数据库 介绍
  • 【机器学习】机器学习重塑广告营销:精准触达,高效转化的未来之路
  • 常见的Java运行时异常
  • CANoe的capl调用Qt制作的dll
  • 论如何搭建属于自己的服务器?
  • 【C++ OpenCV】机器视觉-二值图像和灰度图像的膨胀、腐蚀、开运算、闭运算
  • STMF4学习笔记RTC(天空星)
  • vue数组变化的侦测***
  • k8s-第十节-Ingress
  • webrtc gcc详解
  • Linux多进程和多线程(七)进程间通信-信号量
  • 【项目日记(一)】梦幻笔耕-数据层实现
  • ElementUI的中国省市区级联数据插件element-china-area-data
  • Kotlin算法:把一个整数向上取值为最接近的2的幂指数值