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

前提条件:
数据库中现存在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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值