SQL:多列匹配(Multiple-column Matching)

目录

基础概念

 应用场景详解 

1. 多列等值匹配 

2. 多列 IN 匹配(集合匹配)

3. 多列 JOIN 匹配(复合键连接)

4. 多列匹配 + 子查询

5. 多列匹配 + EXISTS

6. 多列匹配 + UNION(组合数据源)

7. 多列匹配 + 索引优化

性能优化与注意事项


在 MySQL 中,多列匹配(Multiple-column Matching)是指在查询过程中同时对多列进行组合匹配的操作。它通常出现在 WHERE 子句、IN 子句、JOIN 条件或索引使用场景中,具有重要的性能和逻辑意义。

基础概念

多列匹配指的是将多个列组合在一起参与条件判断,形式如下:

SELECT * FROM table
WHERE (col1, col2) = ('value1', 'value2');

 这种写法表示:只有当 col1 = 'value1'col2 = 'value2' 同时成立时,才匹配成功。

 应用场景详解 

1. 多列等值匹配 

说明:
当数据表有复合主键或唯一约束字段组合时,我们经常使用多列匹配来确保查询唯一一条数据。

示例:

SELECT * FROM enrollment
WHERE (student_id, course_id) = (1001, 3002);

 用于查找 student_id 为 1001,course_id 为 3002 的具体记录。高效、简洁,且比 AND 更具有表达力。

2. 多列 IN 匹配(集合匹配)

说明:
当我们需要查找多组组合数据时,可以使用多列 IN ((v1,v2), (v3,v4)) 语法。

示例:

SELECT * FROM enrollment
WHERE (student_id, course_id) IN ((1001, 3002), (1002, 3003), (1003, 3004));

 表示查找这三组组合中的记录。适用于批量查找、批量更新等场景。

3. 多列 JOIN 匹配(复合键连接)

说明:
JOIN 连接表时,如果两个表使用多个字段作为连接键,应使用多列匹配,代码清晰、性能高。

示例:

SELECT *
FROM orders o
JOIN shipments s
ON (o.order_id, o.customer_id) = (s.order_id, s.customer_id);

对于有联合外键的表(order_id + customer_id),这种连接方式逻辑更准确。

4. 多列匹配 + 子查询

说明:
在需要从另一张表中获取一组组合值并在主表中匹配时,子查询返回多列进行匹配非常实用。

示例 1:子查询返回多个列,主查询多列匹配 

SELECT * FROM orders o
WHERE (o.customer_id, o.product_id) IN (SELECT customer_id, product_idFROM popular_productsWHERE year = 2024
);

获取下单用户中,在 2024 年最热门产品中出现过的所有订单。子查询返回的是一组 customer_id + product_id 的组合。

示例 2:带子查询的 NOT IN 

SELECT * FROM orders o
WHERE (o.customer_id, o.product_id) NOT IN (SELECT customer_id, product_idFROM blacklist_products
);

 排除所有在黑名单中的商品组合。

5. 多列匹配 + EXISTS

说明:
比多列 IN 更推荐用于大型子查询,尤其在子表行数多时。

SELECT * FROM orders o
WHERE EXISTS (SELECT 1 FROM popular_products pWHERE o.customer_id = p.customer_id AND o.product_id = p.product_id
);

EXISTS 利用索引更容易走子查询优化路径,适合复杂或数据量大的情况。

6. 多列匹配 + UNION(组合数据源)

说明:
有时候我们需要从多个子集合中组合多列条件,再在主表中匹配。

SELECT * FROM orders o
WHERE (o.customer_id, o.product_id) IN (SELECT customer_id, product_id FROM vip_ordersUNIONSELECT customer_id, product_id FROM recent_orders
);

多来源组合式过滤,避免复杂 OR 查询。

7. 多列匹配 + 索引优化

说明:
MySQL 支持为多个列创建复合索引,使多列匹配执行更高效。

CREATE INDEX idx_customer_product ON orders (customer_id, product_id);

当你执行 (customer_id, product_id) = (...),这会直接命中复合索引,大幅提升性能。

 

性能优化与注意事项

项目建议/注意
 使用复合索引多列匹配配合复合索引使用效果最佳
 匹配顺序一致WHERE 中列顺序必须和索引顺序一致
IN 数量过多元组太多(上千个)会造成执行效率下降
 使用 EXISTS 替代 IN在子表数据量大时更优
 不支持模糊匹配不能使用 (col1, col2) LIKE (...)
 使用 EXPLAIN 分析查看查询是否正确命中索引
  • 使用复合索引:对多列使用索引组合查询效率远高于多个单列索引。

  • 避免列顺序错误:WHERE 中多列顺序需匹配索引顺序。

  • 避免使用过多元组 IN 查询:IN ((a,b), (c,d)) 中元组过多时,会影响性能。

  • 搭配 EXPLAIN 使用:分析查询是否命中索引。

EXPLAIN SELECT * FROM enrollment
WHERE (student_id, course_id) = (101, 203);

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

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

相关文章

基于DeepSeek的智能客服系统实践与创新

引言:AI大模型重塑客户服务新范式 近年来,AI大模型技术的突破性进展正在深刻改变传统客户服务模式。作为国内领先的AI企业,DeepSeek凭借其创新的算法架构(如MoE混合专家模型、动态学习率调度器)和极致的成本效益(仅为同类模型成本的1/20),在自然语言理解、情感分析、多…

SGLang和vllm比有什么优势?

环境: SGLang vllm 问题描述: SGLang和vllm比有什么优势? 解决方案: SGLang和vLLM都是在大语言模型(LLM)推理和部署领域的开源项目或框架,它们各自有不同的设计目标和优势。下面我综合目前…

三、Hive DDL数据库操作

在 Apache Hive 中,数据库 (Database),有时也被称为模式 (Schema),是组织和管理 表及其他对象的基本命名空间单元。熟练掌握数据库层面的数据定义语言 (DDL) 操作,是构建清晰、有序的 Hive 数据仓库的第一步。本篇笔记将详细梳理 …

Redis(2):Redis + Lua为什么可以实现原子性

Redis 作为一款高性能的键值对存储数据库,与 Lua 脚本相结合,为实现原子性操作提供了强大的解决方案,本文将深入探讨 Redis Lua 实现原子性的相关知识 原子性概念的厘清 在探讨 Redis Lua 的原子性之前,我们需要明确原子性的概念…

科普:极简的AI乱战江湖

本文无图。 大模型 ‌2022年2月,‌文生图应用的鼻祖Midjourney上线。 ‌2022年8月,‌开源版的Midjourney,也就是Stable Diffusion上线。 2022年11月30日‌,OpenAI正式发布ChatGPT-3.5。 此后,不断有【大模型】面世&…

CSS- 4.5 css + div 布局 简易网易云音乐 官网布置实例

本系列可作为前端学习系列的笔记,代码的运行环境是在HBuilder中,小编会将代码复制下来,大家复制下来就可以练习了,方便大家学习。 HTML系列文章 已经收录在前端专栏,有需要的宝宝们可以点击前端专栏查看! 点…

【滑动窗口】LeetCode 1004题解 | 最大连续1的个数 Ⅲ

最大连续1的个数 Ⅲ 一、题目链接二、题目三、题目解析四、算法原理解法一:暴力枚举 zero计数器解法二:滑动窗口 五、编写代码六、时空复杂度 一、题目链接 最大连续1的个数 Ⅲ 二、题目 三、题目解析 注意题目中说的是最多k次,在一个数组…

PyTorch音频处理技术及应用研究:从特征提取到相似度分析

文章目录 音频处理技术及应用音频处理技术音视频摘要技术音频识别及应用 梅尔频率倒谱系数音频特征尔频率倒谱系数简介及参数提取过程音频处理快速傅里叶变换(FFT)能量谱处理离散余弦转换 练习案例:音频建模加载音频数据源波形变换的类型绘制波形频谱图波形Mu-Law 编…

鸿蒙OSUniApp 实现的语音输入与语音识别功能#三方框架 #Uniapp

UniApp 实现的语音输入与语音识别功能 最近在开发跨平台应用时,客户要求添加语音输入功能以提升用户体验。经过一番调研和实践,我成功在UniApp项目中实现了语音输入与识别功能,现将过程和方法分享出来,希望对有类似需求的开发者有…

2025年卫星遥感行业最新发展趋势深度分析

一、国内发展趋势:政策引领与技术突破双轮驱动 (一)政策体系持续完善,顶层设计深化行业发展 国家级战略与标准体系构建 中国政府将卫星遥感产业纳入“十四五”规划核心战略,明确构建“通导遥”一体化空间基础设施。20…

SIP协议栈--osip源码梳理

文章目录 osiposip主体结构体code main函数 状态机转化结构体code状态转换 sip事务结构体code osip_dialog结构体code 创建并发送200 OK响应 osip_message结构体code osip_eventcode 打印接收到的SIP消息 osip OSIP(Open Source Implementation of SIP)…

Linux之Yum源与Nginx服务篇

1.Yum源知识理论总结概括 Yum源概述 Yum 源 即软件仓库的标识,里面承载着软件包集合 Yum源组成 包含模块 【OS】、【everything】、【EPOL】、【debuginfo】、【source】、【update-source】 【os】:简称operator system 它内部包含操作系统的核心组件&#x…

从单体架构到微服务:架构演进之路

引言:当“大货车”遇上“集装箱运输” 在软件开发领域,单体架构曾像一辆载满货物的大货车,将所有功能打包在一个应用中。但随着业务复杂度飙升,这辆“大货车”逐渐陷入泥潭:启动慢如蜗牛、故障波及全局、升级如履薄冰……

AM32电调学习解读九:ESC上电启动关闭全流程波形分析

这是第九篇,前面的文章把各个模块的实现都介绍了一轮,本章是从运行的角度结合波形图,把整个流程走一遍。 先看下一运行的配置,我把一些配置关闭了,这样跑起来会好分析一些,不同配置跑起来效果会有差异。使用…

全球宠物经济新周期下的亚马逊跨境采购策略革新——宠物用品赛道成本优化三维路径

在全球"孤独经济"与"银发经济"双轮驱动下,宠物用品市场正经历结构性增长。Euromonitor数据显示,2023年全球市场规模突破1520亿美元,其中中国供应链贡献度达38%,跨境电商出口增速连续三年超25%。在亚马逊流量红…

reshape/view/permute的原理

在pytorch中,Tensor的存储是行主序的,也就是意味着最后一个维度的元素的存储时连续的,reshape和view并不改变元素存储的内存,仅仅改变访问的间隔,下面举例说明; 比如一个23的Tensor在内存中的存储是连续的&…

upload-labs靶场通关详解:第11关

一、分析源代码 $is_upload false; $msg null; if (isset($_POST[submit])) {if (file_exists(UPLOAD_PATH)) {$deny_ext array("php","php5","php4","php3","php2","html","htm","phtml"…

L1-7 最短字母串【保姆级详细讲解】

请你设计一个程序,该程序接受起始字母和目标字母作为输入,通过在字母表中向前或向后移动来计算两个给定字母之间的最短路径。然后,程序会沿着最短路径打印出从起始字母到目标字母的所有字母。例如,如果输入“c”和“k”作为起始字…

项目QT+ffmpeg+rtsp(三)——延迟巨低的项目+双屏显示

文章目录 前言双屏显示widget.cppwidget.h前言 对于复现情况,分为两种情况 第一种,对于我而言,是直接解压后,就能直接运行了 第二种,对于师兄而言,需要你构建debug后,会产生这个文件夹,执行的时候,地址应该在这,我猜的,这里面没有dll,exe程序就找不到dll这些库,你…

ansible进阶06

复杂的循环结构 循环基础 [studentworktest myansible]$ cat users.yml --- - name: create usershosts: serveratasks:- name: create some usersuser:name: "{{item}}"password: "{{123456|password_hash(sha512)}}"state: presentloop:- zhangsan- li…