数据库的查询和视图培训课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《数据库的查询和视图培训课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 查询 视图 培训 课件
- 资源描述:
-
1、数据库的查询和视图(优选)数据库的查询和视图4.1 数据库的查询数据库的查询下面介绍SELECT语句,它是T-SQL的核心。语法主体格式如下:SELECT/*指定查询结果输出列*/INTO 新表 /*指定查询结果存入新表*/FROM ,./*指定查询源:表或视图*/WHERE /*指定查询条件*/GROUP BY /*指定查询结果分组条件*/HAVING /*指定查询结果分组统计条件*/ORDER BY /*指定查询结果排序顺序*/选择查询结果输出列选择查询结果输出列1选择所有列选择所有列使用“*”表示选择一个表或视图中的所有列。【例4.1】查询pxscj数据库中xsb表的所有记录。T-SQL
2、命令如下:USE pxscjSELECT*FROM xsb选择查询结果输出列选择查询结果输出列执行结果如图4.1所示。选择查询结果输出列选择查询结果输出列2选择一个表中指定的列选择一个表中指定的列可选择一个表中的部分列,各列名之间要以逗号分隔。【例4.2】查询xsb表中计算机专业学生的学号、姓名和总学分。T-SQL命令如下:SELECT 学号,姓名,总学分FROM xsbWHERE 专业=计算机选择查询结果输出列选择查询结果输出列3定义列别名定义列别名当希望查询结果中的列使用自己选择的列标题时,可以AS更改列标题名,该列标题称为该列的别名。【例4.3】查询xsb表中计算机系同学的学号、姓名和总
3、学分,查询结果中各列的标题分别指定为number、name和mark。T-SQL命令如下:SELECT 学号 AS number,姓名 AS name,总学分 AS markFROM xsbWHERE 专业=计算机执行结果如图4.2所示。选择查询结果输出列选择查询结果输出列也可以使用“列别名=表达式”更改列标题。例如:SELECT number=学号,name=姓名,mark=总学分FROM xsbWHERE 专业=计算机当自定义的列标题中含有空格时,必须使用引号将标题括起来。例如:SELECT Student number =学号,姓名 AS Student name,mark=总学分FRO
4、M xsbWHERE 专业=计算机选择查询结果输出列选择查询结果输出列4替换查询结果中的数据替换查询结果中的数据在对表进行查询时,有时希望对所查询的某些列得到的数据进行变换。要替换查询结果中的数据,则可使用CASE表达式,格式为:CASE WHEN 条件1 THEN 表达式1 WHEN 条件2 THEN 表达式2 ELSE 表达式END选择查询结果输出列选择查询结果输出列【例4.4】查询xsb表中计算机系各同学的学号、姓名和总学分,对其总学分按以下规则进行替换,列标题更改为“等级”。若总学分为空值,则替换为“尚未选课”;若总学分小于50,则替换为“不及格”;若总学分在50与52之间,则替换为“
5、合格”;若总学分大于52,则替换为“优秀”。T-SQL命令如下:SELECT 学号,姓名,等级=CASE WHEN 总学分 IS NULL THEN 尚未选课WHEN 总学分=50 and 总学分50分人数 FROM xsb WHERE 总学分50;GO选择查询条件:选择查询条件:WHERE子句子句1表达式比较表达式比较比较运算符用于比较两个表达式值,共有9个,分别是=(等于)、(小于)、(大于)、=(大于等于)、(不等于)、!=(不等于)、!(不大于)。比较运算的格式为:表达式1 比较运算符 表达式2其中,“表达式”是除text、ntext和image以外类型的表达式。【例4.11】查询xs
6、b表中通信工程专业总学分大于等于42的同学的情况。T-SQL命令如下:SELECT*FROM xsbWHERE 专业=通信工程 AND 总学分=42选择查询条件:选择查询条件:WHERE子句子句2模式匹配模式匹配LIKE谓词用于指出字符串是否与指定的字符串相匹配,返回逻辑值TRUE或FALSE。格式为:表达式 NOT LIKE 模式串 ESCAPE 转义符 说明:说明:(1)表达式:一般为字符串表达式,在查询语句中可以是列名。(2)模式串:可以使用通配符,表4.2列出了LIKE谓词可以使用的通配符及其说明。(3)转义符:应为有效的SQL Server字符,没有默认值,且必须为单个字符。当模式串
7、中含有与通配符相同的字符时,应通过该字符前的转义符指明其为模式串中的一个匹配字符。使用ESCAPE可指定转义符。(4)NOT LIKE:使用NOT LIKE与LIKE的作用相反。通 配 符说 明%代表倒数_(下画线)代表单个字符 指定范围(如a-f、0-9)或集合(如abcdef)中的任何单个字符指定不属于范围(如 a-f、0-9)或集合(如abcdef)的任何单个字符选择查询条件:选择查询条件:WHERE子句子句【例4.12】查询xsb表中姓“王”且单名的学生情况。T-SQL命令如下,执行结果如图4.9所示。SELECT *FROM xsbWHERE 姓名 LIKE 王_ 选择查询条件:选择
8、查询条件:WHERE子句子句【例4.13】查询xsb表中学号倒数第5个数字为9,且倒数第1个数在15之间的学生学号、姓名及专业。T-SQL命令如下,执行结果如图4.10所示。SELECT 学号,姓名,专业 FROM xsb WHERE 学号 LIKE%9_ _ _1-5 选择查询条件:选择查询条件:WHERE子句子句【例4.13】查询xsb表姓名中倒数第2个字为玉的学生学号、姓名及专业。T-SQL命令如下,执行结果如图4.10所示。SELECT 学号,姓名,专业 FROM xsb WHERE 学号 LIKE%玉_3 以顾客为关注焦点,服务至上,理解顾客当前和未来的要求,满足顾客要求并争取超越顾
9、客的期望。11检验和验收依据中华人民共和国招标投标法、中华人民共和国政府采购法和评标委员会和评标方法暂行规定,结合项目特点,评标严格按照招标文件的要求和条件进行。“公平、公正、择优、效益”为本次评标的基本原则,评标委员会将按照这一原则的要求,公正、平等地对待各投标人。同时,在评标时恪守以下原则:塑造顾客价值人们在改变惯性的时候会觉得不舒服和不习惯,潜意识会不由自主地回到从前。如何来克服这种情况呢?例如,藤本身具有很强的弹性,在制作藤椅的过程中,需要用火烘烤藤,使之慢慢变形,在压力的作用下,藤才会真正变成所期望的形状。1、总则:为增强员工安全生产、环境保护意识,提高员工的安全操作和自我保护能力,
10、确保安全生产,防止环境污染,并依据国家安全生产相关的法律法规,结合我加气站实际情况,制定本制度6.1熟悉CNG汽车充气工艺和检查标准。4.6.3岗位安全技术操作规程,岗位将衔接配合的安全注意事项五、自我约束机制(15)无重大违法记录声明10、确定成交候选人8.1竞争性磋商响应文件正本、所有副本,应分别封装于不同的密封袋内,密封袋上应分别标上“正本”、“副本”、并注明竞争性磋商响应人名称、采购项目编号、采购项目名称。1、货、款监控选择查询条件:选择查询条件:WHERE子句子句3范围比较范围比较(1)当要查询的条件是某个值的范围时,可以使用BETWEEN关键字。BETWEEN关键字指出查询范围,格
11、式为:表达式 NOT BETWEEN 表达式1 AND 表达式2当不使用NOT时,若“表达式”的值在“表达式1”与“表达式2”之间(包括这两个值),则返回TRUE,否则返回FALSE;当使用NOT时,返回值刚好相反。【例4.14】查询xsb表中不在1995年出生的学生情况。T-SQL命令如下,执行结果如图4.11所示。SELECT 学号,姓名,专业,出生时间 FROM xsb WHERE 出生时间 NOT BETWEEN 1995-1-1 and 1995-12-31也可使用下列命令:SELECT 学号,姓名,专业,出生时间 FROM xsb WHERE WHERE year(出生时间)!=1
12、995选择查询条件:选择查询条件:WHERE子句子句图4.11 执行结果选择查询条件:选择查询条件:WHERE子句子句(2)使用IN关键字可以指定一个值表,值表中列出所有可能的值,当与值表中的任一个匹配时,即返回TRUE,否则返回FALSE。格式为:表达式 IN(表达式,)【例4.15】查询xsb表中专业为“软件工程”或“通信工程”学生情况。T-SQL命令如下:SELECT *FROM xsbWHERE 专业 IN(软件工程,通信工程)下列T-SQL命令等价:SELECT *FROM xsbWHERE 专业=计算机 OR 专业=通信工程 选择查询条件:选择查询条件:WHERE子句子句4空值比较
13、空值比较当需要判定一个表达式的值是否为空值时,使用IS NULL关键字,格式为:表达式 IS NOT NULL当不使用NOT时,若表达式的值为空值,则返回TRUE,否则返回FALSE;当使用NOT时,结果刚好相反。【例4.16】查询总学分尚不定的学生情况。SELECT *FROM xsbWHERE 备注 IS NULL选择查询条件:选择查询条件:WHERE子句子句5子查询子查询1)IN子查询子查询IN子查询用于进行一个给定值是否在子查询结果集中的判断,格式为:表达式 NOT IN (子查询)当表达式与子查询的结果表中的某个值相等时,IN谓词返回TRUE,否则返回FALSE;若使用了NOT,则返
14、回的值刚好相反。【例4.17】查询选修了课程号为206的课程的学生情况。T-SQL命令如下:SELECT*FROM xsbWHERE 学号 IN (SELECT 学号 FROM cjb WHERE 课程号=206)本例中,先执行子查询:SELECT 学号FROM cjb WHERE 课程名=206选择查询条件:选择查询条件:WHERE子句子句【例4.18】查询未选修离散数学的学生学号和姓名。T-SQL命令如下:SELECT 学号,姓名FROM xsbWHERE 学号 NOT IN(SELECT 学号 FROM cjb WHERE 课程号 IN(SELECT 课程号 FROM kcb WHERE
15、 课程名=离散数学)选择查询条件:选择查询条件:WHERE子句子句2)比较子查询)比较子查询这种子查询可以认为是IN子查询的扩展,它使表达式的值与子查询的结果进行比较运算,格式为:表达式 比较运算符 ALL|SOME|ANY (子查询)其中,ALL、SOME和ANY说明对比较运算的限制。【例4.19】查询选修了离散数学的学生学号和姓名。T-SQL命令如下:SELECT 学号FROM cjbWHERE 课程号=(SELECT 课程号 FROM kcb WHERE 课程名=离散数学);选择查询条件:选择查询条件:WHERE子句子句【例4.20】查询比所有计算机系的学生年龄都大的学生。T-SQL命令
16、如下:SELECT *FROM xsbWHERE 出生时间 ALL(SELECT 出生时间FROM xsbWHERE 专业=计算机)【例4.21】查询206课程号成绩不低于101课程号最低成绩的学生学号。T-SQL命令如下:SELECT 学号 FROM cjbWHERE 课程号=206 AND 成绩!=50)AS student WHERE 性别=1执行结果如图4.13所示。指定查询对象:指定查询对象:FROM子句子句【例4.28】在xsb表中查询在1995年1月1日以前出生的学生的姓名和专业。T-SQL命令如下,执行结果如图4.14所示。SELECT student.name,student
17、.specialityFROM (SELECT*FROM xsb WHERE 出生时间=80连接连接(2)多表连接。)多表连接。有时,用户所需要的字段来自两个以上的表,那么就要对两个以上的表进行连接,称之为多表连接。【例4.32】查询选修了“计算机基础”课程且成绩在80分以上的学生学号、姓名、课程名及成绩。T-SQL命令如下,执行结果如图4.16所示。SELECT xsb.学号,姓名,课程名,成绩FROM xsb,kcb,cjbWHERE xsb.学号=cjb.学号 AND kcb.课程号=cjb.课程号AND 课程名=计算机基础 AND 成绩=80连接连接2以以JOIN关键字指定的连接关键字
18、指定的连接T-SQL扩展了以JOIN关键字指定连接的表示方式,使表的连接运算能力有所增强。FROM子句的表示将多个表连接起来。格式如下::=ON|CROSS JOIN|左表源 CROSS|OUTER APPLY 右表源|()连接连接说明:(1):准备要连接的表。(2):表示连接类型。格式为::=INNER|LEFT|RIGHT|FULL OUTER JOIN其中,INNER表示内连接,OUTER表示外连接。(3)ON:用于指定连接条件,为连接的条件。(4)APPLY运算符:使用APPLY运算符可以为实现查询操作的外部表表达式返回的每个行调用表值函数。(5)CROSS JOIN:表示交叉连接。连
19、接连接因此,以JOIN关键字指定的连接有三种类型:内连接、外连接、交叉连接。内连接。指定了INNER关键字的连接是内连接,内连接按照ON所指定的连接条件合并两个表,返回满足条件的行。【例4.33】查询每个学生的情况以及选修的课程情况。T-SQL命令如下:SELECT *FROM xsb INNER JOIN cjb ON xsb.学号=cjb.学号执行的结果将包含xsb表和cjb表的所有字段(不去除重复字段学号)。【例4.34】查询选修了206课程且成绩在80分以上的学生姓名及成绩。T-SQL命令如下:SELECT 姓名,成绩FROM xsb JOIN cjb ON xsb.学号=cjb.学号
20、 WHERE 课程号=206 AND 成绩=80连接连接【例4.35】查询选修了“计算机基础”课程且成绩在80分以上的学生学号、姓名、课程名及成绩。T-SQL命令如下:SELECT xsb.学号,姓名,课程名,成绩FROM xsb JOIN cjb JOIN kcb ON cjb.课程号=kcb.课程号 ON xsb.学号=cjb.学号 WHERE 课程名=计算机基础 AND 成绩=80 作为一种特例,可以将一个表与它自身进行连接,称为自连接。【例4.36】查询不同课程成绩相同的学生的学号、课程号和成绩。T-SQL命令如下:SELECT a.学号,a.课程号,b.课程号,a.成绩FROM cj
21、b a JOIN cjb b ON a.成绩=b.成绩 AND a.学号=b.学号 AND a.课程号!=b.课程号执行结果如图4.17所示。连接连接 外连接。指定了OUTER关键字的为外连接,外连接的结果表不但包含满足连接条件的行,还包括相应表中的所有行。外连接包括以下三种:LEFT OUTER JOIN(左外连接):结果表中除了包括满足连接条件的行外,还包括左表的所有行。RIGHT OUTER JOIN(右外连接):结果表中除了包括满足连接条件的行外,还包括右表的所有行。FULL OUTER JOIN(完全外连接):结果表中除了包括满足连接条件的行外,还包括两个表的所有行。连接连接【例4.
展开阅读全文