博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据库SQL语言语法总结4---数据更新
阅读量:4005 次
发布时间:2019-05-24

本文共 1303 字,大约阅读时间需要 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叫做子(属性列作为外码的关系表),数据更新操作时,先更新父,再更新子,而删除操作时,先杀子,再杀父

转载地址:http://wdzfi.baihongyu.com/

你可能感兴趣的文章
[今日关注]鼓吹“互联网泡沫,到底为了什么”
查看>>
[互联网学习]如何提高网站的GooglePR值
查看>>
[关注大学生]求职不可不知——怎样的大学生不受欢迎
查看>>
[关注大学生]读“贫困大学生的自白”
查看>>
[互联网关注]李开复教大学生回答如何学好编程
查看>>
[关注大学生]李开复给中国计算机系大学生的7点建议
查看>>
[关注大学生]大学毕业生择业:是当"鸡头"还是"凤尾"?
查看>>
[茶余饭后]10大毕业生必听得歌曲
查看>>
gdb调试命令的三种调试方式和简单命令介绍
查看>>
C++程序员的几种境界
查看>>
VC++ MFC SQL ADO数据库访问技术使用的基本步骤及方法
查看>>
VUE-Vue.js之$refs,父组件访问、修改子组件中 的数据
查看>>
Vue-子组件改变父级组件的信息
查看>>
Python自动化之pytest常用插件
查看>>
Python自动化之pytest框架使用详解
查看>>
【正则表达式】以个人的理解帮助大家认识正则表达式
查看>>
性能调优之iostat命令详解
查看>>
性能调优之iftop命令详解
查看>>
非关系型数据库(nosql)介绍
查看>>
移动端自动化测试-Windows-Android-Appium环境搭建
查看>>