第三章 标准SQL语言3-3_第1页
第三章 标准SQL语言3-3_第2页
第三章 标准SQL语言3-3_第3页
第三章 标准SQL语言3-3_第4页
第三章 标准SQL语言3-3_第5页
已阅读5页,还剩56页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、1第三章第三章 关系数据库标准语言关系数据库标准语言SQL3.1 SQL概述概述3.2 学生学生-课程数据库课程数据库3.3 数据定义数据定义3.4 数据查询数据查询3.5 数据更新数据更新3.6 视图视图3.7 小结小结23.5 数数 据据 更更 新新 3.5.1 3.5.1 插入数据插入数据3.5.2 3.5.2 修改数据修改数据3.5.3 3.5.3 删除数据删除数据 33.5.1 插入数据插入数据v两种插入数据方式两种插入数据方式1. 1. 插入元组插入元组2. 2. 插入子查询结果插入子查询结果可以一次插入多个元组可以一次插入多个元组 4一、插入元组一、插入元组v语句格式语句格式IN

2、SERTINTO ( (1, 2 )VALUES ( 1 , 2 ) )v功能功能n将新元组插入指定表中将新元组插入指定表中5插入元组(续)插入元组(续)v INTO子句子句n属性列的顺序可与表定义中的顺序不一致属性列的顺序可与表定义中的顺序不一致n没有指定属性列没有指定属性列n指定部分属性列指定部分属性列v VALUES子句子句n 提供的值必须与提供的值必须与INTOINTO子句匹配子句匹配值的个数值的个数值的类型值的类型6插入元组(续)插入元组(续)例例1 1 将一个新学生元组(学号:将一个新学生元组(学号:200215128200215128;姓名:陈冬;性别:男;所在系:姓名:陈冬;性

3、别:男;所在系:ISIS;年龄:;年龄:1818岁)插入到岁)插入到StudentStudent表中。表中。 INSERTINTO Student (Sno,Sname,Ssex,Sdept,Sage)VALUES (200215128,陈冬陈冬,男男,IS,18);7插入元组(续)插入元组(续)例例2 将学生张成民的信息插入到将学生张成民的信息插入到Student表中。表中。 INSERTINTO StudentVALUES (200215126,张成民张成民, 男男,18,CS); 8插入元组(续)插入元组(续)例3 插入一条选课记录( 200215128,1 )。 INSERTINTO

4、SC(Sno,Cno)VALUES ( 200215128 , 1 );INSERTINTO SCVALUES ( 200215128 , 1 ,NULL);9二、插入子查询结果二、插入子查询结果v语句格式语句格式 INSERT INTO ( ( 1 , 2 ) ) 子查询子查询;v功能功能 将子查询结果插入指定表中将子查询结果插入指定表中10插入子查询结果(续)插入子查询结果(续)v INTO子句子句(与插入元组类似与插入元组类似)v 子查询子查询nSELECT子句目标列必须与子句目标列必须与INTO子句匹配子句匹配值的个数值的个数值的类型值的类型11插入子查询结果(续)插入子查询结果(续)

5、例4 对每一个系,求学生的平均年龄,并把结果对每一个系,求学生的平均年龄,并把结果存入数据库。存入数据库。 第一步:建表第一步:建表 CREATE TABLE Dept_age (Sdept CHAR(15) /* 系名系名*/ Avg_age SMALLINT); /*学生平均学生平均年龄年龄*/12插入子查询结果(续)插入子查询结果(续)第二步:插入数据第二步:插入数据 INSERT INTO Dept_age(Sdept,Avg_age) SELECT Sdept,AVG(Sage) FROM Student GROUP BY Sdept;13插入子查询结果(续)插入子查询结果(续)RD

6、BMSRDBMS在执行插入语句时会检查所插元组是在执行插入语句时会检查所插元组是否破坏表上已定义的完整性规则否破坏表上已定义的完整性规则 实体完整性实体完整性 参照完整性参照完整性 用户定义的完整性用户定义的完整性NOT NULLNOT NULL约束约束UNIQUEUNIQUE约束约束值域约束值域约束143.5 数数 据据 更更 新新 3.5.1 插入数据插入数据3.5.2 修改数据修改数据3.5.3 删除数据删除数据 153.4.2 修改数据修改数据v语句格式语句格式 UPDATE SET =,= WHERE ;v功能功能n修改指定表中满足修改指定表中满足WHEREWHERE子句条件的元组子

7、句条件的元组16修改数据(续)修改数据(续)nSET子句子句指定修改方式指定修改方式要修改的列要修改的列修改后取值修改后取值nWHERE子句子句指定要修改的元组指定要修改的元组缺省表示要修改表中的所有元组缺省表示要修改表中的所有元组17修改数据(续)修改数据(续)v三种修改方式三种修改方式1. 修改某一个元组的值修改某一个元组的值2. 修改多个元组的值修改多个元组的值3. 带子查询的修改语句带子查询的修改语句181. 修改某一个元组的值修改某一个元组的值例5 将学生200215121的年龄改为22岁 UPDATE StudentSET Sage=22WHERE Sno= 200215121 ;

8、 192. 修改多个元组的值修改多个元组的值例6 将所有学生的年龄增加1岁 UPDATE StudentSET Sage= Sage+1;203. 带子查询的修改语句带子查询的修改语句例7 将计算机科学系全体学生的成绩置零。 UPDATE SCSET Grade=0WHERE CS= (SELETE Sdept FROM Student WHERE Student.Sno = SC.Sno);21修改数据(续)修改数据(续)RDBMS在执行修改语句时会检查修改操作在执行修改语句时会检查修改操作是否破坏表上已定义的完整性规则是否破坏表上已定义的完整性规则n实体完整性实体完整性n主码不允许修改主码

9、不允许修改n用户定义的完整性用户定义的完整性 NOT NULL约束约束 UNIQUE约束约束 值域约束值域约束223.5 数数 据据 更更 新新 3.5.1 插入数据插入数据3.5.2 修改数据修改数据3.5.3 删除数据删除数据 233.5.3 删除数据删除数据v语句格式语句格式 DELETE FROM WHERE ;v功能功能n删除指定表中满足删除指定表中满足WHEREWHERE子句条件的元组子句条件的元组vWHEREWHERE子句子句n指定要删除的元组指定要删除的元组n缺省表示要删除表中的全部元组,表的定义仍在缺省表示要删除表中的全部元组,表的定义仍在字典中字典中24删除数据(续)删除数

10、据(续)v三种删除方式三种删除方式1. 删除某一个元组的值删除某一个元组的值2. 删除多个元组的值删除多个元组的值3. 带子查询的删除语句带子查询的删除语句251. 删除某一个元组的值删除某一个元组的值例例8 删除学号为删除学号为200215128的学生记录。的学生记录。 DELETEFROM StudentWHERE Sno= 200215128 ;262. 删除多个元组的值删除多个元组的值例例9 删除所有的学生选课记录。删除所有的学生选课记录。 DELETEFROM SC;273. 带子查询的删除语句带子查询的删除语句 例例10 10 删除计算机科学系所有学生的选课记录。删除计算机科学系所

11、有学生的选课记录。 DELETEFROM SCWHERE CS= (SELETE Sdept FROM Student WHERE Student.Sno=SC.Sno);28第三章第三章 关系数据库标准语言关系数据库标准语言SQL3.1 SQL概述概述3.2 学生学生-课程数据库课程数据库3.3 数据定义数据定义3.4 数据查询数据查询3.5 数据更新数据更新3.6 视图视图3.7 小结小结293.6 视视 图图视图的特点视图的特点v 虚表,是从一个或几个基本表(或视图)导出的表虚表,是从一个或几个基本表(或视图)导出的表v 只存放视图的定义,不存放视图对应的数据只存放视图的定义,不存放视图

12、对应的数据v 基表中的数据发生变化,从视图中查询出的数据也随基表中的数据发生变化,从视图中查询出的数据也随之改变之改变303.6 视视 图图基于视图的操作基于视图的操作v 查询查询v 删除删除v 受限更新受限更新v 定义基于该视图的新视图定义基于该视图的新视图313.6 视视 图图3.6.1 定义视图定义视图3.6.2 查询视图查询视图3.6.3 更新视图更新视图3.6.4 视图的作用视图的作用323.6.1 定义视图定义视图v建立视图v删除视图33一、建立视图一、建立视图v 语句格式语句格式 CREATE VIEW ( ,) AS WITH CHECK OPTION;v 组成视图的属性列名:

13、全部省略或全部指定组成视图的属性列名:全部省略或全部指定 P119v 子查询子查询不允许含有不允许含有ORDER BY子句和子句和DISTINCT短语短语34 建立视图(续)建立视图(续)vRDBMS执行执行CREATE VIEW语句时只是把视图语句时只是把视图定义存入数据字典,并不执行其中的定义存入数据字典,并不执行其中的SELECT语语句。句。v在对视图查询时,按视图的定义从基本表中将数在对视图查询时,按视图的定义从基本表中将数据查出。据查出。35建立视图(续)建立视图(续) 例1 建立信息系学生的视图。 CREATE VIEW IS_Student AS SELECT Sno,Sname

14、,Sage FROM Student WHERE Sdept= IS;36建立视图(续)建立视图(续)例例2建立信息系学生的视图,并要求进行修改和插建立信息系学生的视图,并要求进行修改和插入操作时仍需保证该视图只有信息系的学生入操作时仍需保证该视图只有信息系的学生 。 CREATE VIEW IS_StudentAS SELECT Sno,Sname,Sage FROM Student WHERE Sdept= IS WITH CHECK OPTION;37建立视图(续)建立视图(续)对对IS_Student视图的更新操作:视图的更新操作:v修改操作:自动加上修改操作:自动加上Sdept= I

15、S的条件的条件v删除操作:自动加上删除操作:自动加上Sdept= IS的条件的条件v插入操作:自动检查插入操作:自动检查Sdept属性值是否为属性值是否为IS 如果不是,则拒绝该插入操作如果不是,则拒绝该插入操作 如果没有提供如果没有提供Sdept属性值,则自动定义属性值,则自动定义Sdept为为IS38建立视图(续)建立视图(续)v基于多个基表的视图例3 建立信息系选修了1号课程的学生视图。 CREATE VIEW IS_S1(Sno,Sname,Grade) AS SELECT Student.Sno,Sname,Grade FROM Student,SC WHERE Sdept= IS

16、AND Student.Sno=SC.Sno AND SC.Cno= 1;39建立视图(续)建立视图(续)v基于视图的视图基于视图的视图例例4 建立信息系选修了建立信息系选修了1号课程且成绩在号课程且成绩在90分以分以上的学生的视图。上的学生的视图。 CREATE VIEW IS_S2 AS SELECT Sno,Sname,Grade FROM IS_S1 WHERE Grade=90;40建立视图(续)建立视图(续)v带表达式的视图带表达式的视图例例5 定义一个反映学生出生年份的视图。定义一个反映学生出生年份的视图。 CREATE VIEW BT_S(Sno,Sname,Sbirth)AS

17、 SELECT Sno,Sname,2013-Sage FROM Student;41建立视图(续)建立视图(续)v分组视图分组视图例例6 将学生的学号及他的平均成绩定义为一个将学生的学号及他的平均成绩定义为一个视图视图,假设假设SC表中表中“成绩成绩”列列Grade为数字型为数字型 CREAT VIEW S_G(Sno,Gavg) AS SELECT Sno,AVG(Grade) FROM SC GROUP BY Sno;42 建立视图(续)建立视图(续)v 不指定属性列例7将Student表中所有女生记录定义为一个视图 CREATE VIEW F_Student(F_Sno,name,se

18、x,age,dept) AS SELECT * FROM Student WHERE Ssex=女女;缺点: 修改基表Student的结构后,Student表与F_Student视图的映象关系被破坏,导致该视图不能正确工作。43二、删除视图二、删除视图v语句的格式:语句的格式:DROP VIEW ; 该语句从数据字典中删除指定的视图定义该语句从数据字典中删除指定的视图定义 如果该视图上还导出了其他视图,使用如果该视图上还导出了其他视图,使用CASCADE级联删除语句,把该视图和由它导级联删除语句,把该视图和由它导出的所有视图一起删除出的所有视图一起删除 删除基表时,由该基表导出的所有视图定义都

19、删除基表时,由该基表导出的所有视图定义都必须显式地使用必须显式地使用DROP VIEW语句删除语句删除 44删除视图删除视图(续)续)例例8 删除视图删除视图BT_S: DROP VIEW BT_S; 删除视图删除视图IS_S1:DROP VIEW IS_S1;拒绝执行拒绝执行级联删除:级联删除: DROP VIEW IS_S1 CASCADE; 453.6 视视 图图3.6.1 定义视图定义视图3.6.2 查询视图查询视图3.6.3 更新视图更新视图3.6.4 视图的作用视图的作用463.6.2 查询视图查询视图v用户角度:查询视图与查询基本表相同用户角度:查询视图与查询基本表相同vRDBM

20、S实现视图查询的方法实现视图查询的方法 视图消解法(视图消解法(View Resolution) 进行有效性检查进行有效性检查 转换成等价的对基本表的查询转换成等价的对基本表的查询 执行执行修正修正后的查询后的查询47查询视图(续)查询视图(续)例例9 在信息系学生的视图中找出年龄小于在信息系学生的视图中找出年龄小于20岁的岁的学生。学生。 IS_Student视图的定义视图的定义 (参见视图参见视图定义例定义例1)SELECT Sno,SageFROM IS_StudentWHERE Sage20;48查询视图(续)查询视图(续)视图消解转换后的查询语句为:视图消解转换后的查询语句为: SE

21、LECT Sno,Sage FROM Student WHERE Sdept= IS AND Sage=90; S_G视图的子查询定义:视图的子查询定义: CREATE VIEW S_G (Sno,Gavg) AS SELECT Sno,AVG(Grade)FROM SCGROUP BY Sno;52查询转换查询转换错误错误:SELECT Sno,AVG(Grade)FROM SCWHERE AVG(Grade)=90GROUP BY Sno;正确:正确:SELECT Sno,AVG(Grade)FROM SCGROUP BY SnoHAVING AVG(Grade)=90;533.6 视视

22、图图3.6.1 定义视图定义视图3.6.2 查询视图查询视图3.6.3 更新视图更新视图3.6.4 视图的作用视图的作用54更新视图(续)更新视图(续)例例12 将信息系学生视图将信息系学生视图IS_Student中学号中学号200215122的学生姓名改为的学生姓名改为“刘辰刘辰”。UPDATE IS_StudentSET Sname= 刘辰刘辰WHERE Sno= 200215122 ;转换后的语句:转换后的语句:UPDATE StudentSET Sname= 刘辰刘辰WHERE Sno= 200215122 AND Sdept= IS;55更新视图(续)更新视图(续)例例13 向信息系学生视图向信息系学生视图IS_S中插入一个新的学生记录:中插入一个新的学生记录:200215129,赵新,赵新,20岁岁INSERTINTO IS_StudentVALUES(95029,赵新赵新,20);转换为对基本表的更新:转换为对基本表的更新:INSERTINTO Student(Sno,Sname,Sage,Sdept)VALUES(200215129 ,赵新赵新,20,IS );56更新视图(续)更新视图(续)例例14删除信息系学生视图删除信息系学生

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论