教学课件第二章关系数据库语言

上传人:鲁** 文档编号:570192954 上传时间:2024-08-02 格式:PPT 页数:56 大小:580.50KB
返回 下载 相关 举报
教学课件第二章关系数据库语言_第1页
第1页 / 共56页
教学课件第二章关系数据库语言_第2页
第2页 / 共56页
教学课件第二章关系数据库语言_第3页
第3页 / 共56页
教学课件第二章关系数据库语言_第4页
第4页 / 共56页
教学课件第二章关系数据库语言_第5页
第5页 / 共56页
点击查看更多>>
资源描述

《教学课件第二章关系数据库语言》由会员分享,可在线阅读,更多相关《教学课件第二章关系数据库语言(56页珍藏版)》请在金锄头文库上搜索。

1、1第四讲2v设有关系模式S(S#,SNAME,AGE,SEX),C(C#,CNAME,TEACHER),SC(S#,C#,GRADE)。v(1)检索“程军”老师所教授课程的课程号和课程名;v(2)检索年龄大于21的男学生学号和姓名;v(3)检索“李强”同学不学课程的课程号;v(4)检索选修课程名为“C语言”的学生学号和姓名;3 设有一个教学管理数据库系统,其关系模式如下:学生(学号,姓名 ,年级,系别)课程(课程号,课程名,学分数)选课(学号,课程号,成绩) 请用关系代数表达式进行表示: 1.查询“计算机”系4年级学生的学号和姓名。 2.查询选修“数据库”课程的学生的学号、姓名和该门课程的成绩

2、。 4数据库系统第二章关系数据库语言5SQLSQL概述概述vSQL(Structured Query Language) 结构化查询语言,是关系数据库的标准语言vSQL是一个通用的、功能极强的关系数据库语言6SQLSQL标准的进展过程标准的进展过程 标准 大致页数 发布日期vSQL/86 1986.10vSQL/89(FIPS 127-1) 120页 1989年vSQL/92 622页 1992年vSQL99 1700页 1999年vSQL2003 2003年72.1.1 SQL2.1.1 SQL的特点的特点1.综合统一n集数据定义语言(DDL),数据操纵语言(DML),数据控制语言(DCL)

3、功能于一体。n可以独立完成数据库生命周期中的全部活动: 定义关系模式,插入数据,建立数据库; 对数据库中的数据进行查询和更新; 数据库重构和维护 数据库安全性、完整性控制等n用户数据库投入运行后,可根据需要随时逐步修改模式,不影响数据的运行。n数据操作符统一82.2.高度非过程化高度非过程化v非关系数据模型的数据操纵语言“面向过程面向过程”,必须制定存取路径vSQL只要提出“做什么”,无须了解存取路径。v 存取路径的选择以及SQL的操作过程由系统自动完成。93.3.面向集合的操作方式面向集合的操作方式v非关系数据模型采用面向记录的操作方式,操作对象是一条记录vSQL采用集合操作方式 操作对象、

4、查找结果可以是元组的集合 一次插入、删除、更新操作的对象可以是元组的集合104.4.以同一种语法结构提供多种使用方式以同一种语法结构提供多种使用方式vSQL是独立的语言 能够独立地用于联机交互的使用方式vSQL又是嵌入式语言 SQL能够嵌入到高级语言(例如C,C+,Java)程序中,供程序员设计程序时使用115.5.语言简洁,易学易用语言简洁,易学易用vSQL功能极强,完成核心功能只用了9个动词。12SQLSQL的基本概念(续)的基本概念(续)SQL视图2视图1基本表2基本表1基本表3基本表4存储文件2存储文件1外模式模 式内模式SQL支持关系数据库三级模式结构13SQLSQL的基本概念(续)

5、的基本概念(续)v基本表n本身独立存在的表nSQL中一个关系就对应一个基本表n一个(或多个)基本表对应一个存储文件n一个表可以带若干索引v存储文件n逻辑结构组成了关系数据库的内模式n物理结构是任意的,对用户透明v视图n从一个或几个基本表导出的表n数据库中只存放视图的定义而不存放视图对应的数据n视图是一个虚表n用户可以在视图上再定义视图143.2 3.2 学生学生- -课程课程 数据库数据库v学生-课程模式 S-T : 学生表:Student(Sno,Sname,Ssex,Sage,Sdept) 课程表:Course(Cno,Cname,Cpno,Ccredit) 学生选课表:SC(Sno,Cn

6、o,Grade) 15StudentStudent表表学学 号号Sno姓姓 名名Sname性性 别 Ssex年年 龄 Sage所所 在在 系系 Sdept200215121200215122200215123200515125李勇李勇刘晨刘晨王敏王敏张立立男男女女女女男男20191819CSCSMAIS16CourseCourse表表课程号课程号Cno课程名课程名Cname先行课先行课Cpno学分学分Ccredit1234567数据库数据库数学数学信息系统信息系统操作系统操作系统数据结构数据结构数据处理数据处理PASCAL语言语言51676424342417SCSC表表学学 号号Sno 课程号

7、课程号 Cno 成绩成绩 Grade 200215121 200215121 200215121 200215122 200215122 1 2 3 2 3 92 85 88 90 80182.3 数据定义 SQL的数据定义功能: 模式定义、表定义、视图和索引的定义 19基本表的定义、删除与修改基本表的定义、删除与修改一、定义基本表一、定义基本表CREATE TABLE ( , , ); 如果完整性约束条件涉及到该表的多个属性列,则必须定义在表级上,否则既可以定义在列级也可以定义在表级。 20学生表学生表StudentStudent例 建立“学生”表Student,学号是主码,姓名取值唯一。

8、CREATE TABLE Student (Sno CHAR(9) PRIMARY KEY, /* 列级完整性约束条件*/ Sname CHAR(20) UNIQUE, Ssex CHAR(2) , Sage SMALLINT, Sdept CHAR(20); 主码21课程表Coursev 例 建立一个“课程”表Coursev CREATE TABLE Coursev ( Cno CHAR(4) PRIMARY KEY,v Cname CHAR(40), v Cpno CHAR(4) , v Ccredit SMALLINT,v FOREIGN KEY (Cpno) REFERENCES Co

9、urse(Cno) v ); 22学生选课表学生选课表SCSC 例例 建立一个建立一个“学生选课学生选课”表表SCSCCREATE TABLE SC (Sno CHAR(9), Cno CHAR(4), Grade SMALLINT, PRIMARY KEY (Sno,Cno), /* 主码由两个属性构成,必须作为表级完整性进行定义*/ FOREIGN KEY (Sno) REFERENCES Student(Sno), /* 表级完整性约束条件,Sno是外码,被参照表是Student */ FOREIGN KEY (Cno) REFERENCES Course(Cno) /* 表级完整性约束

10、条件, Cno是外码,被参照表是Course*/); 23数据类型数据类型vSQL中域的概念用数据类型来实现v定义表的属性时 需要指明其数据类型及长度 v选用哪种数据类型 n取值范围 n要做哪些运算 24数据类型数据类型数据数据类型型含含义CHAR(n)长度度为n的定的定长字符串字符串VARCHAR(n)最大最大长度度为n的的变长字符串字符串INT长整数(也可以写作整数(也可以写作INTEGER)SMALLINT短整数短整数NUMERIC(p,d)定点数,由定点数,由p位数字(不包括符号、小数点)位数字(不包括符号、小数点)组成,小数后面有成,小数后面有d位位数字数字REAL取决于机器精度的浮

11、点数取决于机器精度的浮点数Double Precision取决于机器精度的双精度浮点数取决于机器精度的双精度浮点数FLOAT(n)浮点数,精度至少浮点数,精度至少为n位数字位数字DATE日期,包含年、月、日,格式日期,包含年、月、日,格式为YYYY-MM-DDTIME时间,包含一日的时、分、秒,格式为时间,包含一日的时、分、秒,格式为HH:MM:SS25修改基本表ALTER TABLE ADD 完整性约束 DROP | ALTER COLUMN ;26修改基本表(续)例向Student表增加“入学时间”列,其数据类型为日期型。 ALTER TABLE Student ADD S_entranc

12、e DATE;不论基本表中原来是否已有数据,新增加的列一律为空值。27v例:用SQL向表Student中增加一列EmailvALTER TABLE STUDENT ADD Email varchar(40).v使用ADD CONSTRAINT 字句添加约束vALTER TABLE STUDENT ADD CONSTRAINT un_name UNIQUE(SName);v或者:ALTER TABLE student ADD UNIQUE(sname); 28v使用ALTER COLUMN 字句修改列属性v将Email列修改成50长度,并允许为空vALTER TABLE STUDENT ALTE

13、R COLUMN Email varchar(50) NULL;29v使用DROP COLUMN子句删除列vALTER TABLE STUDENT DROP COLUMN Email;30删除基本表 DROP TABLE RESTRICT| CASCADE;vRESTRICT:删除表是有限制的。欲删除的基本表不能被其他表的约束所引用如果存在依赖该表的对象,则此表不能被删除vCASCADE:删除该表没有限制。在删除基本表的同时,相关的依赖对象一起删除 31删除基本表(续) 例 删除Student表 DROP TABLE Student CASCADE ;n基本表定义被删除,数据被删除n表上建立的

14、索引、视图、触发器等一般也将被删除 32索引的建立与删除v建立索引的目的:加快查询速度v谁可以建立索引DBA 或 表的属主(即建立表的人)DBMS一般会自动建立以下列上的索引 PRIMARY KEY UNIQUEv谁 维护索引 DBMS自动完成v使用索引 DBMS自动选择是否使用索引以及使用哪些索引33索索 引引vRDBMS中索引一般采用B+树、HASH索引来实现nB+树索引具有动态平衡的优点 nHASH索引具有查找速度快的特点v采用B+树,还是HASH索引 则由具体的RDBMS来决定v索引是关系数据库的内部实现技术,属于内模式的范畴 vCREATE INDEX语句定义索引时,可以定义索引是唯

15、一索引、非唯一索引或聚簇索引 34建立索引 v语句格式CREATE UNIQUE CLUSTER INDEX ON (, );35建立索引(续)建立索引(续)例 CREATE CLUSTER INDEX Stusname ON Student(Sname);在Student表的Sname(姓名)列上建立一个聚簇索引v在最经常查询的列上建立聚簇索引以提高查询效率 v一个基本表上最多只能建立一个聚簇索引 v经常更新的列不宜建立聚簇索引 36建立索引(续) 例为学生-课程数据库中的Student,Course,SC三个表建 立索引。 CREATE UNIQUE INDEX Stusno ON Stu

16、dent(Sno);CREATE UNIQUE INDEX Coucno ON Course(Cno);CREATE UNIQUE INDEX SCno ON SC(Sno ASC,Cno DESC); Student表按学号升序建唯一索引 Course表按课程号升序建唯一索引 SC表按学号升序和课程号降序建唯一索引37删除索引 vDROP INDEX ;删除索引时,系统会从数据字典中删去有关该索引的描述。例 删除Student表的Stusname索引 DROP INDEX Stusname;38数据查询v语句格式 SELECT ALL|DISTINCT , FROM , WHERE GROU

17、P BY HAVING ORDER BY ASC|DESC ;39单表查询 v查询仅涉及一个表:n一、 选择表中的若干列n二、 选择表中的若干元组n三、 ORDER BY子句n四、 聚集函数n五、 GROUP BY子句40一、一、 选择表中的若干列选择表中的若干列v查询指定列例 查询全体学生的学号与姓名。SELECT Sno,SnameFROM Student;412. 查询全部列v选出所有属性列:n在SELECT关键字后面列出所有列名 n将指定为 *例 查询全体学生的详细记录。SELECT *FROM Student; 42为结果集内的列指定别名vSelect SNO AS 学号,SName

18、 As 姓名,Ssex As 性别 from student43为结果集内添加派生列vSELECT SNO,CNO,SCORE=SCORE+20 FROM SC44为结果集消除重复列vSELECT DISTINCT SNAME,SSEX FROM STUDENT;45限制返回行数v例:查询Student表中的所有字段,在结果集中显示表中的前3条记录vSELECT TOP 3 * from student;v例:查询Student表中的所有字段,在结果集中显示表中的前20%条记录vSELECT TOP 20 PERCENT * from student;46使用INTO子句创建新表vSELECT

19、 SNO,SNAME INTO Student2FROM STUDENT;若新表名称以#开头,则为临时表;47使用WHERE子句过滤记录v(1)比较运算符v用于比较大小:、等v查询SC表中所有字段,检索成绩不合格的记录vSELECT * from sc where score60;v查询姓名为“赵丽”的记录vSELECT * from student where SNAME=“赵丽”;48v(2)范围运算符vBETWEEN AND NOT BETWEEN AND 查询SC表中所有字段,成绩在7090的记录SELECT * from sc where score between 70 and 9

20、049查询SC表中所有字段,成绩不在7090的记录SELECT * from sc where score NOT between 70 and 9050v(3)列表运算符v用来判断列值是否在所给定的一个子列表中,包括:vINvNOT INvSELECT * from student where SNAME in(赵丽,王华,李刚);51v(4)模式匹配运算符vNOT LIKE ESCAPE 1)匹配串为固定字符串例14 查询学号为200215121的学生的详细情况。 SELECT * FROM Student WHERE Sno LIKE 200215121;等价于: SELECT * FR

21、OM Student WHERE Sno = 200215121 ;52 2) 匹配串为含通配符的字符串例 查询所有姓刘学生的姓名、学号和性别。 SELECT Sname,Sno,Ssex FROM Student WHERE Sname LIKE 刘%;例 查询姓欧阳且全名为三个汉字的学生的姓名。 SELECT Sname FROM Student WHERE Sname LIKE 欧阳_;53例 查询名字中第2个字为阳字的学生的姓名和学号。 SELECT Sname,Sno FROM Student WHERE Sname LIKE _阳%;例 查询所有不姓刘的学生姓名。 SELECT S

22、name,Sno,Ssex FROM Student WHERE Sname NOT LIKE 刘%;543) 使用换码字符将通配符转义为普通字符 例 查询DB_Design课程的课程号和学分。 SELECT Cno,Ccredit FROM Course WHERE Cname LIKE DB_Design ESCAPE ;例 查询以DB_开头,且倒数第3个字符为 i的课程的详细情况。 SELECT * FROM Course WHERE Cname LIKE DB_%i_ _ ESCAPE ; ESCAPE 表示表示“ ” 为换码字符为换码字符 55v(5) 涉及空值的查询n谓词:谓词:

23、IS NULL 或 IS NOT NULLn “IS” 不能用 “=” 代替 例 某些学生选修课程后没有参加考试,所以有选课记录,但没 有考试成绩。查询缺少成绩的学生的学号和相应的课程号。 SELECT Sno,Cno FROM SC WHERE SCORE IS NULL例 查所有有成绩的学生学号和课程号。 SELECT Sno,Cno FROM SC WHERE SCORE IS NOT NULL;56v(6)逻辑运算符v逻辑运算符:AND和 OR来联结多个查询条件v AND的优先级高于ORv 可以用括号改变优先级v可用来实现多种其他谓词v NOT INv NOT BETWEEN AND

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 工作计划

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