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. 优化:建议增加去重条件,避免重复插入
相关推荐
m0_6784854516 小时前
CSS如何控制表格单元格边框合并_通过border-collapse实现
jvm·数据库·python
m0_7488394916 小时前
如何用组合继承模式实现父类方法复用与子类属性独立
jvm·数据库·python
qq_3345635516 小时前
PHP源码是否依赖特定芯片组_Intel与AMD平台差异【操作】
jvm·数据库·python
qq_2069013916 小时前
如何使用C#调用Oracle存储过程_OracleCommand配置CommandType.StoredProcedure
jvm·数据库·python
m0_7488394916 小时前
CSS如何实现元素平滑滚动_使用scroll-behavior属性设置
jvm·数据库·python
星晨雪海17 小时前
Lombok 注解使用场景终极总结
java·数据库·mysql
风子杨yxf77118 小时前
linux下oracle开机自启动以及关机自关闭数据库,并发送邮件通知
linux·运维·数据库·oracle·自启动·发邮件·自关闭
战族狼魂18 小时前
基于LibreOffice +python 实现一个小型销售管理系统的数据库原型教学实验
数据库·python
m0_6403093018 小时前
PHP函数怎样适配高可靠性存储硬件_PHP在ZFS RAIDZ环境配置【技巧】
jvm·数据库·python
踏浪无痕18 小时前
用 AI 解决数据库性能问题的方法论
数据库