删除学习“叶平”老师课的sc表记录

要删除学习叶平 老师课程的成绩表(SC)记录,需要多表关联定位数据:

  1. Teacher表找到叶平的教师编号t_no
  2. 通过t_noCourse表找到对应课程编号c_no
  3. 通过c_noSC表找到需要删除的成绩记录

SQL 实现代码

MySQL / Oracle 通用写法(推荐,兼容性最好)

sql

复制代码
-- 删除学习叶平老师课程的SC表记录
DELETE FROM sc
WHERE sc.c_no IN (
    -- 子查询:获取叶平老师教授的所有课程编号
    SELECT course.c_no 
    FROM course
    JOIN teacher ON course.t_no = teacher.t_no  -- 课程表关联教师表
    WHERE teacher.tname = '叶平'  -- 筛选教师姓名为叶平
);

多表连接删除写法(MySQL 专用)

sql

复制代码
-- MySQL 多表连接删除
DELETE sc
FROM sc
JOIN course ON sc.c_no = course.c_no
JOIN teacher ON course.t_no = teacher.t_no
WHERE teacher.tname = '叶平';

代码说明

  1. 核心逻辑 :通过教师表→课程表→成绩表的关联关系,精准定位要删除的成绩记录
  2. 子查询作用 :先查出叶平老师教的所有课程编号,再删除成绩表中对应课程的记录
  3. 安全提示 :执行DELETE前,建议先执行SELECT查询确认要删除的数据,避免误删:

sql

复制代码
-- 先查询验证数据(必做!)
SELECT * FROM sc
WHERE sc.c_no IN (
    SELECT course.c_no 
    FROM course
    JOIN teacher ON course.t_no = teacher.t_no
    WHERE teacher.tname = '叶平'
);

总结

  1. 多表删除需逐层关联定位目标数据
  2. 优先使用IN子查询写法,适配所有数据库
  3. 删除前必须用SELECT验证数据,防止误操作
相关推荐
知识分享小能手12 分钟前
R语言入门学习教程,从入门到精通,R语言多维数据可视化(12)
学习·信息可视化·r语言
我命由我1234514 小时前
程序员的心理学学习笔记 - 空杯心态
经验分享·笔记·学习·职场和发展·求职招聘·职场发展·学习方法
stm32 菜鸟15 小时前
nucleo-f411re学习记录-13,flash的操作
学习
晓梦林15 小时前
3170靶场学习笔记
笔记·学习
ErizJ15 小时前
Redis|学习笔记
redis·笔记·学习
加油201916 小时前
方法论:如何系统性的学习?
学习·学习方法·方法论
小t说说16 小时前
科学素养培养:男孩女孩的不同“方程式”,真的有分性别学习平台?
学习
xian_wwq16 小时前
【学习笔记】变电保护、测控、安自、自动化系统概述
笔记·学习·保护
lizhihai_9917 小时前
股市学习心得—商业航天10大核心材料供应商
大数据·人工智能·学习
泰勒朗斯17 小时前
rootflight学习笔记
笔记·学习