INSERT INTO ... SELECT ...

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(成绩),语句中对应的值:

  1. 第一个值Sid → 学生学号(来自外层查询)
  2. 第二个值'002' → 固定课程号 002
  3. 第三个值(SELECT AVG(Score) FROM SC WHERE Cid='002') → 标量子查询,计算002 号课程的所有学生平均分

3. 筛选条件

sql

复制代码
WHERE Sid NOT IN (SELECT Sid FROM SC WHERE Cid='003')

只选择没有选修 003 号课程的学生。


完整执行逻辑

  1. 先计算:002 号课程的所有成绩平均分
  2. 再查找:所有没选 003 号课程的学生学号
  3. 最后批量插入:给这些学生,新增一条002课程的选课记录,成绩为步骤 1 的平均分

注意事项

  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');
  2. 空值问题 如果 002 号课程没有任何成绩,AVG(Score)会返回NULL,插入的成绩会是空值。

  3. 语法兼容性该语句在 MySQL、Oracle、SQL Server 中都能正常运行。

总结

  1. 功能:批量给未选 003 课的学生,插入 002 课的平均分成绩
  2. 核心:INSERT INTO ... SELECT 批量插入 + 标量子查询算平均分
  3. 优化:建议增加去重条件,避免重复插入
相关推荐
lzhdim2 小时前
SQL 入门 7:SQL 聚合与分组:函数、GROUP BY 与 ROLLUP
java·服务器·数据库·sql·mysql
Uso_Magic2 小时前
SQLSERVER__EXPLAIN 常用分析案例。
服务器·数据库·sql
IAtlantiscsdn2 小时前
Redis面试题总结
数据库·redis·缓存
2501_924952693 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
诗酒当趁年华3 小时前
langchain核心组件1-智能体
数据库·langchain
流星白龙3 小时前
【MySQL】9.MySQL内置函数
android·数据库·mysql
原来是猿3 小时前
MySQL 在 Centos 7环境安装
数据库·mysql·centos
路小雨~4 小时前
Milvus 向量数据库的官方文档笔记
数据库·学习·milvus
老衲提灯找美女4 小时前
数据库约束
数据库