0

0

mysql集合相关SQL如何学习_mysql入门路径推荐

P粉602998670

P粉602998670

发布时间:2026-01-10 10:25:02

|

654人浏览过

|

来源于php中文网

原创

MySQL无原生集合类型,SET仅为位图压缩字符串枚举,不支持动态集合运算;多值场景应优先用关联表,JSON数组需权衡性能代价;集合逻辑可用UNION/JOIN/NOT IN等基础语法模拟。

mysql集合相关sql如何学习_mysql入门路径推荐

MySQL 中没有原生的「集合类型」(如 Python 的 set 或 SQL 标准中的 ARRAY),所谓“集合相关 SQL”,实际是指对**多值场景的模拟与处理**——比如去重、交集、并集、差集、枚举约束、JSON 数组字段查询等。初学者容易误以为 MySQL 有 SET 类型就能当集合用,结果在业务中踩坑不断。

别把 SET 当集合用:它只是字符串枚举

MySQL 的 SET 数据类型看起来像集合(支持存多个预定义值,如 SET('a','b','c')),但它底层是**位图压缩的字符串**,不是真正的数学集合:

  • 插入 'a,b''b,a' 存储效果相同(自动排序+去重),但你无法用它做动态交集计算
  • 不能索引单个成员(WHERE my_set LIKE '%b%' 会全表扫描)
  • 不支持 UNION/INTERSECT 等集合运算(MySQL 8.0.19+ 才支持 INTERSECTEXCEPT,且仅用于查询结果集,非字段级)
  • 真正需要集合语义时,应拆成关联表(如 user_tags(user_id, tag_id)

用标准 SQL 模拟集合运算:UNIONNOT ININNER JOIN

MySQL 早于 8.0.19 版本不支持 INTERSECTEXCEPT,但所有集合逻辑都能用基础语法组合实现:

SELECT id FROM table_a
INTERSECT
SELECT id FROM table_b;

等价写法(兼容所有版本):

SELECT a.id 
FROM table_a a 
INNER JOIN table_b b ON a.id = b.id;

差集(A - B)不用 EXCEPT,改用:

SELECT id FROM table_a 
WHERE id NOT IN (SELECT id FROM table_b WHERE id IS NOT NULL);

注意NOT IN 遇到子查询含 NULL 会整个返回空——必须加 WHERE ... IS NOT NULL 过滤,否则逻辑出错。

Sider
Sider

多功能AI浏览器助手,帮助用户进行聊天、写作、阅读、翻译等

下载

JSON 字段里存数组?先想清楚性能代价

MySQL 5.7+ 支持 JSON 类型,很多人用它存标签列表:{"tags": ["mysql", "sql", "index"]}。看似灵活,但:

  • JSON_CONTAINS(json_col, '"mysql"') 可查,但**无法走索引**(除非建函数索引,如 CREATE INDEX idx_tag ON t ((CAST(json_extract(tags, '$[0]') AS CHAR)))
  • 更新单个 tag 要读-改-写整字段,高并发下易锁表
  • 聚合统计(如“每个 tag 出现次数”)必须用 JSON_TABLE() 拆开,性能远低于关联表 GROUP BY tag_id

真实业务中,只要 tag/分类/权限等关系超过 3 个值、且需频繁查询或关联,就该用规范的多对多表结构。

入门路径推荐:从「能跑通」到「敢优化」分三步走

别一上来就啃《高性能 MySQL》。按真实使用节奏推进:

  • 第 1 周:只学 DQL + 小数据集练习 —— 在 SQLZOO牛客网 SQL 题库 刷完 50 道题,重点练 JOINGROUP BYHAVINGORDER BY LIMIT。不装 MySQL,浏览器里敲就行
  • 第 2 周:本地装 MySQL 8.0,动手建真实小表 —— 比如 usersordersproducts,自己导 1000 行测试数据,执行 EXPLAIN SELECT ...typeALL 还是 ref,感受索引有没有生效
  • 第 3 周:聚焦一个痛点深挖 —— 比如发现某条 SELECT 很慢,就专门查它:开 slow_query_log,用 EXPLAIN FORMAT=TREE(8.0+),看是否走了索引、有没有临时表、是否文件排序。这时候再回头读《MySQL 必知必会》第 12 章或官网 EXPLAIN 输出说明

集合操作本身不难,难的是判断什么时候该用关联表、什么时候能妥协用 JSON、什么时候必须上中间件分片——这些决策点,永远藏在慢查询日志和 EXPLAINrows 字段里,而不是语法手册中。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

744

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

634

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

757

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1259

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

577

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

705

2023.08.11

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

25

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号