数据库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叫做子(属性列作为外码的关系表),数据更新操作时,先更新父,再更新子,而删除操作时,先杀子,再杀父
- 数据库SQL语言语法总结4---数据更新
- 数据库SQL语言语法总结6---数据控制
- 数据库SQL语言语法总结5---视图
- 数据库SQL语言语法总结2---索引
- 数据库SQL语言语法总结7---嵌入式SQL
- sql 数据库语法总结
- 数据库SQL语言语法总结3---查询语句
- 数据库SQL语言语法总结1---表操作
- oracle数据库中sql语言创建表,更新,删除数据
- SQL数据库基础语法总结
- sql 数据库语法总结2
- SQL语言基础-数据更新
- SQL语言-数据更新操作
- 数据库更新Sql脚本总结
- 数据库更新Sql脚本总结
- 数据库笔记3————关系数据库标准语言SQL上(SQL的数据定义和数据更新)
- sql 语言总结和语法介绍
- Orcale数据库SQL语言总结
- Oracle查询优化-03操作多个表
- 链表和数组的区别
- 关于Java的全英文博客,值得学习知识和英语非常的有用
- 矩阵下三角元素之和
- [LeetCode]78.Subsets
- 数据库SQL语言语法总结4---数据更新
- 常用正则表达式
- 安卓与JS通信相互调用
- 奇葩的某个类没有被Cglib动态代理,世间仅有
- poj1247
- 删除指定字符
- C++强制类型转换
- vue与angular的区别
- uC/OS-II移植 详解 系统时钟部分