课程设计__查询.ppt

  1. 1、本文档共38页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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]查询数计系、

文档评论(0)

整理王 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档