欢迎来到天天文库
浏览记录
ID:51597527
大小:381.00 KB
页数:81页
时间:2020-03-25
《数据库原理第3章关系数据库标准语言SQL(1).ppt》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、首都师范大学信息工程学院数据库系统原理PrinciplesofDatabaseSystem第三章关系数据库标准语言SQLAnIntroductiontoDatabaseSystem第三章关系数据库标准语言SQL3.1SQL概述3.2数据定义3.3查询3.4数据更新3.5视图3.6数据控制3.7嵌入式SQL3.8小结AnIntroductiontoDatabaseSystem3.1SQL概述SQL的特点1.综合统一2.高度非过程化3.面向集合的操作方式4.以同一种语法结构提供两种使用方法5.语言简洁,易学易用AnInt
2、roductiontoDatabaseSystem5.语言简捷,易学易用AnIntroductiontoDatabaseSystemSQL的基本概念SQL视图2视图1基本表2基本表1基本表3基本表4存储文件2存储文件1外模式模式内模式SQL支持关系数据库三级模式结构AnIntroductiontoDatabaseSystemSQL的基本概念(续)基本表本身独立存在的表SQL中一个关系就对应一个基本表一个(或多个)基本表对应一个存储文件一个表可以带若干索引存储文件逻辑结构组成了关系数据库的内模式物理结构是任意的,对用户
3、透明视图从一个或几个基本表导出的表数据库中只存放视图的定义而不存放视图对应的数据视图是一个虚表用户可以在视图上再定义视图AnIntroductiontoDatabaseSystem第三章关系数据库标准语言SQL3.1SQL概述3.2数据定义3.3查询3.4数据更新3.5视图3.6数据控制3.7嵌入式SQL3.8小结AnIntroductiontoDatabaseSystem3.2数据定义AnIntroductiontoDatabaseSystem3.2.1定义语句格式CREATETABLE<表名>(<列名><数据类型
4、>[<列级完整性约束条件>][,<列名><数据类型>[<列级完整性约束条件>]]…[,<表级完整性约束条件>]);<表名>:所要定义的基本表的名字<列名>:组成该表的各个属性(列)<列级完整性约束条件>:涉及相应属性列的完整性约束条件<表级完整性约束条件>:涉及一个或多个属性列的完整性约束条件AnIntroductiontoDatabaseSystem例题[例1]建立一个“学生”表Student,它由学号Sno、姓名Sname、性别Ssex、年龄Sage、所在系Sdept五个属性组成。其中学号不能为空,值是唯一的,并
5、且姓名取值也唯一。CREATETABLEStudent(SnoCHAR(5)NOTNULLUNIQUE,SnameCHAR(20)UNIQUE,SsexCHAR(1),SageINT,SdeptCHAR(15));AnIntroductiontoDatabaseSystem定义基本表(续)常用完整性约束主码约束:PRIMARYKEY唯一性约束:UNIQUE非空值约束:NOTNULL参照完整性约束AnIntroductiontoDatabaseSystem例题(续)[例2]建立一个“学生选课”表SC,它由学号Sno、课
6、程号Cno,修课成绩Grade组成,其中(Sno,Cno)为主码。CREATETABLESC(SnoCHAR(5),CnoCHAR(3),Gradeint,Primarykey(Sno,Cno));AnIntroductiontoDatabaseSystem例题(续)AnIntroductiontoDatabaseSystem三、删除基本表DROPTABLE<表名>;基本表删除数据,表上的索引都删除表上的视图往往仍然保留,但无法引用删除基本表时,系统会从数据字典中删去有关该基本表及其索引的描述(标准中没有,认为表建立
7、后就永久存在)AnIntroductiontoDatabaseSystem例题[例5]删除Student表DROPTABLEStudent;AnIntroductiontoDatabaseSystem二、修改基本表ALTERTABLE<表名>[ADD<新列名><数据类型>[完整性约束]][DROP<完整性约束名>][MODIFY<列名><数据类型>];<表名>:要修改的基本表ADD子句:增加新列和新的完整性约束条件DROP子句:删除指定的完整性约束条件MODIFY子句:用于修改列名和数据类型AnIntroductio
8、ntoDatabaseSystem例题[例2]向Student表增加“入学时间”列,其数据类型为日期型。ALTERTABLEStudentADDScomeDATE;不论基本表中原来是否已有数据,新增加的列一律为空值。AnIntroductiontoDatabaseSystem语句格式(续)删除属性列直接/间接删除把表中要保留的列及其内容复制到一
此文档下载收益归作者所有