• SQL语言(二)数据更新


    数据更新

    数据更新操作有三种:

    • 向表中添加若干行数据
    • 修改表中的数据
    • 删除表中的若干行数据

    在SQL中有相应的三类语句

    插入数据

    插入语句INSERT通常有两种形式,一种是插入一个元组,另一种是插入子查询的结果。后者可以一次插入多个元组。

    插入元组

    将一个新学生元组插入到Student表中
    use school1
    GO
    INSERT
    INTO Student(Sno,Sname,Ssex,Sdept,Sage)
    VALUES('S07','陈冬','男','软件工程',18)
    
    • 1
    • 2
    • 3
    • 4
    • 5

    修改前:
    在这里插入图片描述
    修改后:
    在这里插入图片描述

    对每一个系,求学生的平均年龄,并把结果存入数据库

    首先在数据库中建立一个新表,其中一列存放系名,另一列存放相应的学生平均年龄。

    CREATE TABLE Dept_age
             (Sdept CHAR(15)
    		    Avg_age SMALLINT)
    
    • 1
    • 2
    • 3

    然后对Student表按系分组表示平均年龄,再把系名和平均年龄存入新表中。

    INSERT 
    INTO Dept_age(Sdept,Avg_age)
    SELECT Sdept.AVG(Sage)
    FROM Student
    GROUP BY Sdept
    
    • 1
    • 2
    • 3
    • 4
    • 5

    修改数据

    将学生的年龄改为22岁

    修改前:
    在这里插入图片描述
    修改后:
    在这里插入图片描述

    将所有学生的年龄都增加一岁
    use school1
    GO
    UPDATE Student
    SET Sage=Sage+1
    
    • 1
    • 2
    • 3
    • 4
    将计算机科学系全体学生的成绩置零
    use school1
    GO
    UPDATE SC
    SET Grade=0
    WHERE Sno IN 
         (SELECT Sno
    	  FROM Student
    	  WHERE Sdept='计算机'	 
    	 )
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    删除数据

    删除某一个学生的学生记录

    use school1
    GO
    DELETE 
    FROM Student
    WHERE Sno='S07'
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    修改前:
    在这里插入图片描述
    修改后:
    在这里插入图片描述

    空值处理

    选出选修1号课程的不及格的学生及缺考的学生
    use school1
    GO
    SELECT Sno
    FROM SC
    WHERE Grade<60 AND Cno='C01'
    UNION
    SELECT Sno
    FROM SC
    WHERE Grade IS NULL  AND Cno='CO1'
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    视图

    定义视图

    建立数学系学生的视图
    use school1
    GO
    CREATE VIEW IS_Student
    AS
    SELECT Sno,Sname,Sage
    FROM Student
    WHERE Sdept='数学'
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述
    在这里插入图片描述

    建立数学系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有数学系的学生
    use school1
    GO
    CREATE VIEW IS_Student
    AS
    SELECT Sno,Sname,Sage
    FROM Student
    WHERE Sdept='数学'
    WITH CHECK OPTION
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    建立自动化系选修了1号课程的学生的视图(包括学号、姓名、成绩)
    use school1
    GO
    CREATE VIEW IS_S1tudent(Sno,Sname,Grade)
    AS
    SELECT Student.Sno,Sname,Grade
    FROM Student,SC
    WHERE Sdept='自动化'AND Student.Sno=SC.Sno AND SC.Cno='C01'
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    定义一个反映学生出生年份的视图
    use school1
    GO
    CREATE VIEW BT_S(Sno,Sname,Sbirth)
    AS
    SELECT Sno,Sname,2014-Sage
    FROM Student
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述

    将学生的学号及平均成绩定义为一个视图
    use school1
    GO
    CREATE VIEW S_G(Sno,Gavg)
    AS
    SELECT Sno,AVG(Grade)
    FROM SC
    GROUP BY Sno
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述

    删除视图

    删除视图BT_S和视图IS_SI

    use school1
    GO
    DROP VIEW BT_S
    DROP VIEW IS_S1tudent
    
    • 1
    • 2
    • 3
    • 4

    查询视图

    在数学系学生的视图中找出年龄小于20岁的学生
    use school1
    GO
    SELECT Sno,Sage
    FROM IS_Student
    WHERE Sage<20
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    在S_G视图中查询平均成绩在80分以上的学生学号和平均成绩
    use school1
    GO
    SELECT Sno,AVG(Grade)
    FROM SC
    GROUP BY Sno
    HAVING AVG(Grade)>=80
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    在这里插入图片描述

    更新视图

    更新视图是指通过视图来插入、删除和修改数据。
    由于视图是不实际存储数据的虚表,因此对视图的更新最终要转换为对基本表的更新
    将数学系学生视图IS_Student中学号为“S06”的学生姓名改为“长江”

    use school1
    GO
    UPDATE IS_Student
    SET Sname='长江'
    WHERE Sno='S06'  
    
    • 1
    • 2
    • 3
    • 4
    • 5
  • 相关阅读:
    Linux常用命令
    常用 Git 命令
    普通索引和唯一索引,应该怎么选择?
    U-BOOT小全(三):SPL框架
    设计模式:桥接模式
    一些有趣的迹象:“前端已死”难道要成真了?
    进程控制的一些具体操作
    unity shader用渲染纹理实现镜子效果
    【洛谷 P8682】[蓝桥杯 2019 省 B] 等差数列 题解(数学+排序+差分)
    项目沟通管理&干系人管理
  • 原文地址:https://blog.csdn.net/Algernon98/article/details/127762508