第三章关系数据库标准语言SQL学习资料

上传人:yuzo****123 文档编号:137412813 上传时间:2020-07-08 格式:PPT 页数:136 大小:683.50KB
返回 下载 相关 举报
第三章关系数据库标准语言SQL学习资料_第1页
第1页 / 共136页
第三章关系数据库标准语言SQL学习资料_第2页
第2页 / 共136页
第三章关系数据库标准语言SQL学习资料_第3页
第3页 / 共136页
第三章关系数据库标准语言SQL学习资料_第4页
第4页 / 共136页
第三章关系数据库标准语言SQL学习资料_第5页
第5页 / 共136页
点击查看更多>>
资源描述

《第三章关系数据库标准语言SQL学习资料》由会员分享,可在线阅读,更多相关《第三章关系数据库标准语言SQL学习资料(136页珍藏版)》请在金锄头文库上搜索。

1、第三章 关系数据库标准语言SQL,本章主要教学内容:,数据定义、查询、数据更新 视图 数据控制 嵌入式SQL,3.1 SQL 概述,3.1.1 SQL 的特点,SQL是一个介于关系代数与关系演算之间的结构化查询语言,其功能不只是查询。SQL是一个通用的、功能极强的关系数据库查询语言。,1. 一体化特点;,2. 高度非过程化;,3.面向集合的操作方式;,4.对待不同的工作方式采用统一的语法结构;,5.语言简洁,易学易用;,6. 视图数据结构,3.1.2 SQL语言的基本概念,SQL语言支持关系数据库三级模式结构视图、基本表和存储文件。,外模式,模式,内模式,利用SQL进行数据库操作可分三个阶段进

2、行:,定义数据库结构,定义关系模式; 向已定义的数据库中添加、删除和修改数据; 对已存在数据库进行各种查询与统计。,3.2.1 定义、删除与修改基本表,一、定义基本表,命令格式:,CREATE TABLE ( , , ):所要定义的基本表的名字,说明: :组成该表的各个属性(列) :涉及相应属性列的完整性约束条件 :涉及一个或多个属性列的完整性约束条件,例1 建立一个“学生”表Student,它由学号Sno、姓名Sname、性别Ssex、年龄Sage、所在系Sdept五个属性组成。其中学号不能为空,值是唯一的,并且姓名取值也唯一。 CREATE TABLE Student (Sno CHAR(

3、5) NOT NULL UNIQUE, Sname CHAR(20) UNIQUE, Ssex CHAR(1) , Sage INT, Sdept CHAR(15),常用完整性约束: 唯一性约束:UNIQUE 非空值约束:NOT NULL 参照完整性约束 主码约束: PRIMARY KEY,例2 建立一个“学生选课”表SC,它由学号Sno、课程号Cno,修课成绩Grade组成。,CREATE TABLE SC( Sno CHAR(5) , Cno CHAR(3) , Grade int),二、修改扩充基本表,ALTER TABLE ADD 完整性约束 DROP MODIFY ;,说明: :要修

4、改的基本表 ADD子句:增加新列和新的完整性约束条件 DROP子句:删除指定的完整性约束条件 MODIFY子句:用于修改列名和数据类型,命令格式:,例4 将年龄的数据类型改为半字长整数。,ALTER TABLE Student MODIFY Sage SMALLINT,注:修改原有的列定义有可能会破坏已有数据。,例5 删除学生姓名必须取唯一值的约束。,ALTER TABLE Student DROP UNIQUE(Sname),例3 向Student表增加“入学时间”列,其数据类型为日期型。,ALTER TABLE Student ADD Scome DATE,注:不论基本表中原来是否已有数据

5、,新增加的列一律为空。,三、删除基本表,DROP TABLE ,命令格式:,说明: 删除基本表及其数据,释放相应的存储空间,同时系统也自动删除在此表上建立的各种索引,也删除了在该表上授予的操作权限。 表上的视图往往仍然保留,但无法引用。,例7 删除Student表,DROP TABLEStudent,3.2.2 建立与删除索引,建立索引是加快查询速度的有效手段 建立索引 DBA或表的属主(即建立表的人)根据需要建立 有些DBMS自动建立以下列上的索引 PRIMARY KEY UNIQUE 维护索引( DBMS自动完成) 使用索引 DBMS自动选择是否使用索引以及使用哪些索引,一、建立索引,命令

6、格式: CREATE UNIQUE CLUSTER INDEX ON (, );,说明: 用指定要建索引的基本表名字 索引可以建立在该表的一列或多列上,各列名之间用逗号分隔 用指定索引值的排列次序,升序:ASC,降序:DESC。缺省值:ASC UNIQUE表明此索引的每一个索引值只对应唯一的数据记录 CLUSTER表示要建立的索引是聚簇索引,所谓聚簇索引是指索引项的顺序与表中记录的物理顺序一致的索引组织。,例8 为学生-课程数据库中的Student,Course,SC三个表建立索引。其中Student表按学号升序建唯一索引,Course表按课程号升序建唯一索引,SC表按学号升序和课程号降序建唯

7、一索引。,CREATE UNIQUE INDEX Stusno ON Student(Sno) CREATE UNIQUE INDEX Coucno ON Course(Cno) CREATE UNIQUE INDEX SCno ON SC(Sno ASC,Cno DESC),说明:,(1)唯一值索引 对于已含重复值的属性列不能建UNIQUE索引 对某个列建立UNIQUE索引后,插入新记录时DBMS会自动检查新记录在该列上是否取了重复值。这相当于增加了一个UNIQUE约束,(2)聚簇索引 建立聚簇索引后,基表中数据也需要按指定的聚簇属性值的升序或降序存放。也即聚簇索引的索引项顺序与表中记录的物

8、理顺序一致。,例: CREATE CLUSTER INDEX Stusname ON Student(Sname) 在Student表的Sname(姓名)列上建立一个聚簇索引,而且Student表中的记录将按照Sname值的升序存放,(3)在一个基本表上最多只能建立一个聚簇索引;,(4)聚簇索引的适用范围 很少对基表进行增删操作 很少对其中的变长列进行修改操作,二、删除索引,DROP INDEX ,例9 删除Student表的Stusname索引。,DROP INDEX Stusname;,注意:建立索引是为了减少查询操作时间,但如果数据增加删改频繁,系统会花费许多时间来维护索引。,命令格式:

9、,3.3 查 询,语句格式 SELECT ALL|DISTINCT , FROM , WHERE GROUP BY HAVING ORDER BY ASC|DESC ,功能:根据WHERE子句中的条件,从FROM后面列出的表名中找出满足条件的元组,按SELECT子句后面给出的列名1,列名2等目标列的顺序,选出元组中的分量形成结果表。,说明: SELECT子句:指定要显示的属性列 FROM子句:指定查询对象(基本表或视图) WHERE子句:指定查询条件 GROUP BY子句:对查询结果按指定列的值分组,该属性列值相等的元组为一个组。通常会在每组中作用集函数。 HAVING短语:筛选出只有满足指定

10、条件的组 ORDER BY子句:对查询结果表按指定列值的升序(ASC)或降序(DESC)排序,3.3.1 单表查询,查询仅涉及一个表,是一种最简单的查询操作,一、选择表中的若干列 二、选择表中的若干元组 三、对查询结果排序 四、使用集函数 五、对查询结果分组,一、选择表中的若干列,例1 查询全体学生的学号与姓名。,1. 查询指定列:,SELECT Sno,Sname FROM Student,例2 查询全体学生的姓名、学号、所在系。,SELECT Sname,Sno,Sdept FROM Student,例3 查询全体学生的详细记录。,SELECT Sno,Sname,Ssex,Sage,Sd

11、ept FROM Student 或 SELECT * FROM Student,2. 查询全部列:,3. 查询经过计算的值:,SELECT子句的为表达式 算术表达式 字符串常量 函数 列别名,例4 查全体学生的姓名及其出生年份。,SELECT Sname,2000-Sage FROM Student,Sname 2000-Sage 李勇 1976 刘晨 1977 王名 1978 张立 1978,输出结果:,例5 查询全体学生的姓名、出生年份和所在系,要求用小写字母表示所有系名。,SELECT Sname,Year of Birth: ,2000-Sage, ISLOWER(Sdept) FR

12、OM Student,输出结果: Sname Year of Birth: 2000-Sage ISLOWER(Sdept) 李勇 Year of Birth: 1976 cs 刘晨 Year of Birth: 1977 is 王名 Year of Birth: 1978 ma 张立 Year of Birth: 1977 is,例6 使用列别名改变查询结果的列标题,SELECT Sname NAME,Year of Birth: BIRTH, 2000-Sage BIRTHDAY,ISLOWER(Sdept) DEPARTMENT FROM Student;,输出结果: NAME BIRT

13、H BIRTHDAY DEPARTMENT 李勇 Year of Birth: 1976 cs 刘晨 Year of Birth: 1977 is 王名 Year of Birth: 1978 ma 张立 Year of Birth: 1977 is,二、选择表中的若干元组,1. 消除取值重复的行,方法:在SELECT子句中使用DISTINCT短语。,假设SC表中有下列数据 Sno Cno Grade 95001 1 92 95001 2 85 95001 3 88 95002 2 90 95002 3 80,例7 查询选修了课程的学生学号。,(1) SELECT Sno FROM SC,(2

14、) SELECT DISTINCT Sno FROM SC,结果1,结果2,结果1: Sno 95001 95001 95001 95002 95002,结果2: Sno 95001 95002,注意: DISTINCT短语的作用范围是所有目标列。,例:查询选修课程的各种成绩 错误的写法 SELECT DISTINCT Cno,DISTINCT Grade FROM SC 正确的写法 SELECT DISTINCT Cno,Grade FROM SC,2. 查询满足条件的元组,见P95 表3.3,(1)比较大小:,在WHERE子句的中使用比较运算符 =,=,!,! 逻辑运算符NOT + 比较运

15、算符,例8 查询所有年龄在20岁以下的学生姓名及其年龄。,SELECT Sname,Sage FROM Student WHERE Sage 20,例9 查询考试成绩有不及格的学生的学号,SELECT DISTINCT Sno FROM SC WHERE Grade 60,(2)确定范围:,使用谓词 BETWEEN AND 、NOT BETWEEN AND ,例10 查询年龄在2023岁(包括20岁和23岁)之间的学生的姓名、系别和年龄。,SELECT Sname,Sdept,Sage FROM Student WHERE Sage BETWEEN 20 AND 23,年龄不在2023之间的学

16、生: Sage NOT BETWEEN 20 AND 23,(3)确定集合:,使用谓词 IN , NOT IN ,:用逗号分隔的一组取值,例11 查询信息系(IS)、数学系(MA)和计算机科学系(CS)学生的姓名和性别。,SELECT Sname,Ssex FROM Student WHERE Sdept IN ( IS,MA,CS );,查询既不是信息系、数学系,也不是计算机科学系的学生: Sdept NOT IN ( IS,MA,CS ),(4)字符匹配:,格式:NOT LIKE ESCAPE ,功能:查找指定的属性列值与相匹配的元组。匹配串可以是一个完整的字符串,也可以含有通配符。,通配符:% 和_ %(百分号):代表任意长度的字符串; _(下横线):代表

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 教学课件 > 高中课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号