数据库SQL语言语法总结4---数据更新

来源:互联网 发布:多线程编程技术 编辑:程序博客网 时间:2024/05/19 10:35

前提条件:
数据库中现存在3个关系表
Student (Sno ,Sname,Ssex,Sage,Sdept);
解释:学生(学号,学生姓名,学生性别,学生年龄,学生专业);
Course(Cno,Cname,Cpno);
解释:课程(课程号,课程名,可能的先修课程);
SC(Sno,Cno,Grade);
解释:学生选课情况(学号,课程号,成绩);

一: 插入数据
1)插入一个元祖:insert into <表名> [<属性列1>] [,<属性列2>…] values (<常量1>[,<常量2>]…) (常量要与属性列对应,顺序相同)
例1: insert into SC(Sno,Cno) values (‘95020’,’1’)
(当插入数据时未赋值的属性列要么允许为空,要么有默认的初始值,否则数据库将不允许插入)
例2: insert into Student values (‘95020’,’陈冬’,’男’,’IS’,18)

2)插入子查询结果
insert into <表名>[<属性列1>] [,<属性列2>…] 子查询
作用:将子查询查到的结果按照属性列的顺序插入表中
例:insert into Deptage select Sdept ,avg(Sage) from Student group by Sdept (Deptage关系表中只有两个属性列, 系的名称和在这个系中学生的平均年龄)

二:修改数据
ipdate <表名> set <属性列1> = <表达式1> [,<属性列2> = <表达式2>]…
[where <条件>]
作用:将满足where条件的记录的属性列1和属性列2的分量值改为表达式1和表达式2的值
例1: update Student set Sage=22 where Sno = ‘95001’
(将学号为95001的学生的年龄改为22)
例2:update Student set Sage = Sage+1
例3: update SC set Grade=0 where ‘CS’ = (select Sdept from Student where Student.Sno=SC.Sno) ———(将所有CS专业的学生的选修课成绩置为0)

三:删除数据
delete from <表名> [where <条件>]
作用:删除满足where条件的记录
例:delete from Student where Sno = ‘95019’ (删除学号为95019的学生的记录)

更新记录时,要注意参照完整性约束条件。当a表中的属性列1是外码(外码即表示属性列1在a表中不是主码,但在b表中是主码)则当往a表中插入记录时,必须保证此记录在属性列1上的分量在b表中已经存在(即为参照完整性约束条件),总的来说,更新a之前必须先更新b。而当删除b表中记录时,必须先删除a表中的相关记录,再删除b表的记录。我们可以将b叫做父(属性列作为主码的关系表),a叫做子(属性列作为外码的关系表),数据更新操作时,先更新父,再更新子,而删除操作时,先杀子,再杀父

1 0
原创粉丝点击