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.环境

相关推荐
lixora5 分钟前
备份指定oracle block 防止误操作
数据库
凯子坚持 c11 分钟前
Redis 数据库的服务器部署与 MCP 智能化交互深度实践指南
服务器·数据库·redis
DBA小马哥17 分钟前
Oracle迁移金仓全攻略:工业IOT场景下的易用性与安全保障
数据库·物联网·安全·oracle
‘胶己人’18 分钟前
redis分布式锁
数据库·redis·分布式
初恋叫萱萱29 分钟前
基于CodeRider-Kilo和MySQL开发一款书店管理系统
数据库·mysql·产品运营
hid6466372233 分钟前
基于改进粒子群算法的无人机三维路径规划——MATLAB运行效果图
sql
Elastic 中国社区官方博客33 分钟前
通过 Elasticsearch 中的 function score query 按利润和受欢迎程度提升电商搜索效果
大数据·数据库·elasticsearch·搜索引擎·全文检索
qq_3663363737 分钟前
mysql-5.7.38-winx64.zip 启动教程(免安装版)
数据库·mysql·adb
不穿格子的程序员39 分钟前
Redis篇5——Redis深度剖析:系统的“隐形杀手”——热Key与大Key问题
数据库·redis·缓存·热key·大key
·云扬·1 小时前
深入理解MySQL元数据锁(MDL):原理、问题与实践
数据库·mysql