sql的表join怎么学?

1.内连接

✅ 目标:理解两个表之间的匹配关系。

sql 复制代码
SELECT u.id, u.name, o.id AS order_id
FROM users u
INNER JOIN orders o ON u.id = o.user_id;

建议练法:

  1. 用最小数据表(5~10 行)

  2. 手画出笛卡尔积(所有组合)

  3. 观察 ON 条件如何过滤结果

💡 你可以自己造几个 CSV 小表,然后用 SQLite 或 MySQL 本地跑。

2.LEFT / RIGHT JOIN

✅ 目标:理解"以谁为主表"的差别。

sql 复制代码
SELECT u.id, u.name, o.id AS order_id
FROM users u
LEFT JOIN orders o ON u.id = o.user_id;

想一想:

  • 如果用户没下单,会不会出现在结果里?

  • order_id 是 NULL 吗?

👉 画图理解最有效。

3.子查询与分步骤查询

✅ 目标:会用子查询当作"中间结果表"。

sql 复制代码
SELECT player_id
FROM Activity
WHERE event_date = (
  SELECT MIN(event_date)
  FROM Activity a2
  WHERE a2.player_id = Activity.player_id
);

练法:

  • 先独立执行子查询

  • 看返回什么

  • 再嵌入主查询看联动效果

4.窗口函数

✅ 目标:在不分组的情况下,对行做排名或累计。

sql 复制代码
SELECT player_id, event_date,
       RANK() OVER (PARTITION BY player_id ORDER BY event_date) AS rank
FROM Activity;

可以用来:

  • 排名(RANK, ROW_NUMBER)

  • 累计求和(SUM() OVER ...)

  • 环比增长(LAG/LEAD)

5.环境

相关推荐
倔强的石头_2 小时前
从 “存得下” 到 “算得快”:工业物联网需要新一代时序数据平台
数据库
TDengine (老段)2 小时前
TDengine IDMP 可视化 —— 分享
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据·时序数据
GottdesKrieges3 小时前
OceanBase数据库备份配置
数据库·oceanbase
SPC的存折4 小时前
MySQL 8组复制完全指南
linux·运维·服务器·数据库·mysql
运维行者_4 小时前
OpManager MSP NetFlow Analyzer集成解决方案,应对多客户端网络流量监控挑战
大数据·运维·服务器·网络·数据库·自动化·运维开发
炸炸鱼.5 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
softshow10265 小时前
Etsy 把 1000 个 MySQL 分片迁进 Vitess
数据库·mysql
Ronaldinho Gaúch5 小时前
MySQL基础
数据库·mysql
不剪发的Tony老师6 小时前
Noir:一款键盘驱动的现代化数据库管理工具
数据库·sql
.柒宇.7 小时前
MySQL双主同步
linux·数据库·mysql·docker