16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号"003"课程的同学学号、002号课的平均成绩
INSERT INTO SC SELECT Sid,'002', (SELECT AVG(Score) FROM SC WHERE Cid='002') FROM SC WHERE Sid NOT IN (SELECT Sid FROM SC WHERE Cid='003')
1. 核心语法
sql
INSERT INTO SC -- 目标表:学生选课表SC
SELECT ... -- 要插入的数据来源:查询结果
FROM SC -- 数据取自SC表
INSERT INTO ... SELECT ... 是批量插入数据的标准语法,直接把查询结果插入表中。
2. 插入的 3 个字段值
SC 表通常包含 3 列:Sid(学号)、Cid(课程号)、Score(成绩),语句中对应的值:
- 第一个值 :
Sid→ 学生学号(来自外层查询) - 第二个值 :
'002'→ 固定课程号 002 - 第三个值 :
(SELECT AVG(Score) FROM SC WHERE Cid='002')→ 标量子查询,计算002 号课程的所有学生平均分
3. 筛选条件
sql
WHERE Sid NOT IN (SELECT Sid FROM SC WHERE Cid='003')
只选择没有选修 003 号课程的学生。
完整执行逻辑
- 先计算:002 号课程的所有成绩平均分
- 再查找:所有没选 003 号课程的学生学号
- 最后批量插入:给这些学生,新增一条
002课程的选课记录,成绩为步骤 1 的平均分
注意事项
-
重复数据风险 如果学生已经有 002 号课程的成绩,执行后会重复插入,建议先判断是否存在:
sql
-- 优化版:仅插入不存在002课程的学生 INSERT INTO SC SELECT Sid,'002', (SELECT AVG(Score) FROM SC WHERE Cid='002') FROM SC WHERE Sid NOT IN (SELECT Sid FROM SC WHERE Cid='003') -- 新增去重条件 AND Sid NOT IN (SELECT Sid FROM SC WHERE Cid='002'); -
空值问题 如果 002 号课程没有任何成绩,
AVG(Score)会返回NULL,插入的成绩会是空值。 -
语法兼容性该语句在 MySQL、Oracle、SQL Server 中都能正常运行。
总结
- 功能:批量给未选 003 课的学生,插入 002 课的平均分成绩
- 核心:
INSERT INTO ... SELECT批量插入 + 标量子查询算平均分 - 优化:建议增加去重条件,避免重复插入