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. 优化:建议增加去重条件,避免重复插入
相关推荐
百度安全14 小时前
HugeGraph 晋升 Apache 顶级项目 百度安全持续筑牢 AI 时代图数据基础设施
数据库·人工智能·安全·知识图谱
_3762715314 小时前
JavaScript中闭包结合代理模式Proxy实现数据监听
jvm·数据库·python
ShiJiuD66688899914 小时前
综合练习(Javaweb)
数据库
User_芊芊君子14 小时前
从 0 到 1 学 MySQL:索引原理、事务特性、视图用法与 JDBC 实操全解析
大数据·数据库·mysql
八月瓜科技14 小时前
豆包启动付费会员测试,承诺基础服务永久免费,免费AI时代是否终结?
数据库·人工智能·科技·深度学习·机器人
人道领域14 小时前
【黑马点评日记】社交平台用户关注功能全解析Feed流相关操作
java·开发语言·数据库·redis·python
zhoutongsheng14 小时前
mysql如何处理表空间碎片问题_执行OPTIMIZE TABLE整理
jvm·数据库·python
lifewange15 小时前
如何查看本地的数据库里信息
数据库
PSLoverS15 小时前
Python如何实现测试场景编排_基于pytest的数据驱动组合策略
jvm·数据库·python
HalvmånEver15 小时前
MySQL事务(一)
linux·数据库·学习·mysql