您的位置:首页 > 数据库

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

2017-02-07 20:26 393 查看
前提条件:

数据库中现存在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叫做子(属性列作为外码的关系表),数据更新操作时,先更新父,再更新子,而删除操作时,先杀子,再杀父
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息