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. 优化:建议增加去重条件,避免重复插入
相关推荐
运维行者_4 小时前
Applications Manager中的Redis监控
大数据·服务器·数据库·人工智能·网络协议
悦数图数据库7 小时前
图数据库选型指南 2026:从架构、性能、AI 适配三个维度看 悦数科技
数据库·人工智能·架构
handler018 小时前
【MySQL】常用命令总结(库与表增删查改)
运维·数据库·mysql·命令·总结
week@eight8 小时前
Linux - Doris
linux·运维·数据库·mysql
cdbqss19 小时前
VB2026 菜单生成基类 BqGetMenuStrip
数据库·经验分享·学习·oracle·vb
洛水水9 小时前
Redis 分布式锁详解:实现与缺陷
数据库·redis·分布式
韶博雅9 小时前
oracle中表和列转大写
数据库·oracle
暴躁小师兄数据学院10 小时前
【AI大数据工程师特训笔记】第04讲:PostgreSQL 数据库内置函数详解
大数据·数据库·笔记·ai·语言模型
苏渡苇11 小时前
Spring Cloud Alibaba:将 Sentinel 熔断限流规则持久化到 Nacos 配置中心
数据库·spring boot·mysql·spring cloud·nacos·sentinel·持久化