SQL中联表查询深入分析

  • LEFT JOIN 左集合(左表)
  • RIGHT JOIN 右集合(右表)
  • FULL OUTER JOIN 并集
  • JOIN (INNER JOIN) 交集

测试数据表:

sql 复制代码
-- 创建数据库 (可选)
CREATE DATABASE IF NOT EXISTS school_demo;
USE school_demo;

-- 1. 老师表
DROP TABLE IF EXISTS teachers;
CREATE TABLE teachers (
    t_id INT PRIMARY KEY AUTO_INCREMENT,
    t_name VARCHAR(50) NOT NULL,
    subject VARCHAR(50) -- 教授科目
);

-- 2. 课程表 (关联老师)
DROP TABLE IF EXISTS courses;
CREATE TABLE courses (
    c_id INT PRIMARY KEY AUTO_INCREMENT,
    c_name VARCHAR(50) NOT NULL,
    t_id INT, -- 外键,关联老师ID
    credit DECIMAL(3,1) -- 学分
);

-- 3. 学生表
DROP TABLE IF EXISTS students;
CREATE TABLE students (
    s_id INT PRIMARY KEY AUTO_INCREMENT,
    s_name VARCHAR(50) NOT NULL,
    age INT,
    major VARCHAR(50) -- 专业
);

-- 4. 选课记录表 (关联学生和课程)
DROP TABLE IF EXISTS selections;
CREATE TABLE selections (
    id INT PRIMARY KEY AUTO_INCREMENT,
    s_id INT, -- 关联学生
    c_id INT, -- 关联课程
    score INT, -- 分数,NULL表示未考试
    INDEX idx_s (s_id),
    INDEX idx_c (c_id)
);

测试数据:

sql 复制代码
-- 插入老师数据 (5条)
INSERT INTO teachers (t_name, subject) VALUES 
('王老师', '数学'),
('李老师', '英语'),
('赵老师', '计算机'),
('陈老师', '物理'),
('刘老师', '体育');

-- 插入课程数据 (5条,分别对应上面的老师)
INSERT INTO courses (c_name, t_id, credit) VALUES 
('高等数学', 1, 4.0),
('大学英语', 2, 3.0),
('Java编程', 3, 3.5),
('大学物理', 4, 4.0),
('篮球', 5, 1.0);

-- 插入学生数据 (5条)
INSERT INTO students (s_name, age, major) VALUES 
('张三', 20, '计算机'),
('李四', 21, '数学'),
('王五', 20, '物理'),
('赵六', 22, '计算机'),
('钱七', 19, '英语');

-- 插入选课记录数据 (约8条,模拟不同学生选不同课)
INSERT INTO selections (s_id, c_id, score) VALUES 
(1, 1, 85.5), -- 张三选修高等数学
(1, 3, 92.0), -- 张三选修Java编程
(2, 1, 95.0), -- 李四选修高等数学
(2, 2, 88.0), -- 李四选修大学英语
(3, 4, 76.0), -- 王五选修大学物理
(4, 3, 89.0), -- 赵六选修Java编程
(4, 5, 100.0),-- 赵六选修篮球
(5, 2, NULL); -- 钱七选修英语但还未考试(score为NULL)

场景 1:基础联表 (INNER JOIN 或 JOIN) 查询所有选了课的学生姓名、课程名和分数:

sql 复制代码
SELECT 
    s.s_name AS 学生姓名,
    c.c_name AS 课程名,
    sel.score AS 分数
FROM selections sel
JOIN students s ON sel.s_id = s.s_id
JOIN courses c ON sel.c_id = c.c_id;

查询结果:

场景 2:多表联查 (包含老师信息) 查询学生张三选修的课程,以及该课程的任课老师:

sql 复制代码
SELECT 
    s.s_name,
    c.c_name,
    t.t_name AS 老师,
    t.subject
FROM students s
JOIN selections sel ON s.s_id = sel.s_id
JOIN courses c ON sel.c_id = c.c_id
JOIN teachers t ON c.t_id = t.t_id
WHERE s.s_name = '张三';

查询结果

场景 3:左联表 (Left Join) 查询所有学生,以及他们的选课情况(即使没选课的学生也要列出):

sql 复制代码
SELECT 
    s.s_name,
    c.c_name,
    sel.score
FROM students s
LEFT JOIN selections sel ON s.s_id = sel.s_id
LEFT JOIN courses c ON sel.c_id = c.c_id;

查询结果:

相关推荐
indexsunny4 分钟前
互联网大厂Java面试实战:核心技术与微服务架构解析
java·数据库·spring boot·缓存·微服务·面试·消息队列
合方圆~小文6 分钟前
三目智能监控新标杆
数据库·人工智能·模块测试
神秘的猪头8 分钟前
AI全栈项目 Day 3:不仅是数据库,更是你的“数据堡垒” —— PostgreSQL 硬核入门
数据库·sql·postgresql
天人合一peng12 分钟前
kingbase数据库的
服务器·数据库·oracle
雨季66614 分钟前
系统化方法论与实战案例
数据库
数据库知识分享者小北19 分钟前
从极速复制“死了么”APP,看AI编程时代的技术选型
数据库·阿里云·状态模式·ai编程·supabase
想摆烂的不会研究的研究生24 分钟前
并发场景——接口幂等性设计
数据库·redis·后端·缓存
星火开发设计38 分钟前
关系代数:数据库查询的数学基石与实战解析
数据库·学习·oracle·知识·关系代数
u01040583640 分钟前
企业微信第三方应用API对接的Java后端架构设计:解耦与可扩展性实践
java·数据库·企业微信
ascarl201041 分钟前
Oracle 12c 官方卸载工具 (Deinstall Tool) 标准流程
数据库·oracle