- 1、本文档共38页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
课程设计__查询.ppt
查询是数据库的核心操作,数据查询是关系运算理论在SQL语言中的具体体现。 查询语句SELECT的格式: SELECT A1,A2,… , An FROM R1,R2, … , Rm WHERE F 查询的结果就构成一个“视图”。 基本表是独立存在的数据表,直接对应存储文件; 视图是从一个或多个基本表导出来的表,并不独立存储于数据库中(数据库只存放视图的定义而非视图对应的数据),因而是虚表。 视图在概念上与基本表相同,都是关系。 本章用到的表 Student(学生表) SC(选课表) 语句格式 SELECT [ALL|DISTINCT] 目标列表达式(序列) FROM 基本表名(和)或视图名 [ WHERE 行条件表达式 ] [ GROUP BY 列名1 [ HAVING 条件表达式 ] ] [ ORDER BY 列名2 [ ASC|DESC ] ]; SELECT子句:指定要显示的属性列 FROM子句:指定查询对象(基本表或视图) WHERE子句:指定查询条件 GROUP BY子句:对查询结果按指定列的值分组,该属性列值相等的元组为一个组。通常会在每组中作用集函数。 HAVING短语:筛选出只有满足指定条件的组 ORDER BY子句:对查询结果表按指定列值序或降序排序 3.1 单表查询 查询仅涉及一个表,是一种最简单的查询操作,包括: 选择表中的若干列 选择表中的若干元组 对查询结果排序 使用集函数 对查询结果分组 [例1] 查询全体学生的学号与姓名。 SELECT Sno,Sname FROM Student;? ? [例2] 查询全体学生的姓名、学号、所在系。 SELECT Sname,Sno,Sdept FROM Student; SELECT子句后的目标列表达式中各个列的先后顺序可自由改变,无须与表中顺序一致。 [例3] 查询全体学生的详细记录。 SELECT Sno,Sname,Ssex,Sage,Sdept FROM Student; 或 SELECT * FROM Student; SELECT子句的目标列表达式可以是表中属性列,还可以是表达式: 算术表达式、字符串常量、函数、列别名 在SELECT子句中使用DISTINCT短语 两个本来并不同的元组,投影到指定的某些列上后,可能变成相同的行了。 [例6] 查询选修了课程的学生学号。 (1) SELECT Sno FROM SC; (2) SELECT DISTINCT Sno FROM SC; 如果没有指定 DISTINCT 短语,缺省值为ALL,即保留结果表中取值重复的行。 如果没有指定 DISTINCT 短语,缺省值为ALL,即保留结果表中取值重复的行。 DISTINCT短语的作用范围是所有目标列 如:查询选修课程的各种成绩 错误的写法 SELECT DISTINCT Cno,DISTINCT Grade FROM SC; 正确的写法 SELECT DISTINCT Cno,Grade FROM SC; (1) 比较大小 在WHERE子句的比较条件中使用比较运算符 =,,,=,=,!= 或 ,!,!, 逻辑运算符NOT + 比较运算符 [例7] 查询数计系全体学生的名单。 SELECT Sname FROM Student WHERE Sdept =‘数计系; [例8] 查询所有年龄在20岁以下的学生姓名及其年龄。 SELECT Sname,Sage FROM Student WHERE Sage 20; 或 SELECT Sname,Sage FROM Student WHERE NOT Sage = 20; (2) 确定范围 使用谓词 BETWEEN … AND … NOT BETWEEN … AND … [例9] 查询年龄在20~23岁(包括20岁和23岁)之间的学生的姓名、系别和年龄。 SELECT Sname,Sdept,Sage FROM Student WHERE Sage BETWEEN 20 AND 23; (3) 确定集合 查询属性值属于指定集合的元组 使用谓词 IN 值表, NOT IN 值表 值表:用逗号分隔的一组取值 [例10]查询数计系、
您可能关注的文档
- 计算机方面的认证情况.doc
- 计算机毕业论文-员工工资管理系统.doc
- 计算机毕业论文答辩PPT.ppt
- 计算机温度控制系统课程设计.doc
- 计算机物理应用技术绪论第节.ppt
- 计算机硬件实验().ppt
- 计算机硬件拆装实验报告().doc
- 计算机科学与技术oracle实习报告.doc
- 计算机科学与技术在线购书系统毕业设计答辩PPT.ppt
- 计算机科学与技术学院c++课程设计指导书.doc
- 新的一年工作展望.docx
- 医生年终个人工作的述职报告(3篇).docx
- 2023年消防设施操作员之消防设备中级技能考前冲刺练习题附答案详解.docx
- 2022-2023年环境影响评价工程师之环评技术导则与标准通关练习题包括详细解答.docx
- 2023年中级注册安全工程师之安全生产管理考前冲刺检测卷和答案.docx
- 2023年中级银行从业资格之中级银行管理考前冲刺测试卷提供答案解析.docx
- 2023年公共营养师之二级营养师通关模拟考试试卷附带答案.docx
- 证券分析师之发布证券研究报告业务考前冲刺模拟题库.docx
- 2022-2023年二级建造师之二建建设工程法规及相关知识综合提升测试卷附答案.docx
- 2023年二级建造师之二建机电工程实务通关模拟考试试卷提供答案解析.docx
文档评论(0)