- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
DECODE()函数 DECODE(value, if1, then1, if2,then2, if3,then3, . . . else ) Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else select count(*) , decode(region_id,1,欧洲,3,亚洲,其他洲) from countries group by region_id; CASE表达式 简单的CASE表达式 case search_expr when expr_1 then display_result_1 when expr_2 then display_result_2 ……. when expr_n then display_result_n else default_display_result end 搜索CASE表达式 case when expr_1 then display_result_1 when expr_2 then display_result_2 ……. when expr_n then display_result_n else default_display_result end * * 集合查询 一般商用数据库支持的集合操作种类 并操作(UNION) 交操作(INTERSECT) 差操作(EXCEPT) 形式 查询块 UNION |UNION ALL| INTERSECT | MINUS 查询块 参加运算的各结果表的列数必须相同;对应项的数据类型也必须相同 * * 集合查询(续) 查询计算机科学系的学生及年龄不大于19岁的学生. 方法一: 使用并操作 SELECT * FROM Student WHERE Sdept= CS UNION SELECT * FROM Student WHERE Sage=19; 方法二: SELECT DISTINCT * FROM Student WHERE Sdept= CS OR Sage=19; * * 集合查询(续) 查询选修了课程1或者选修了课程2的学生. 方法一: SELECT Sno FROM SC WHERE Cno= 1 UNION SELECT Sno FROM SC WHERE Cno= 2 ; 方法二: SELECT DISTINCT Sno FROM SC WHERE Cno= 1 OR Cno= 2 ; * * 集合查询(续) 查询计算机科学系的学生与年龄不大于19岁的学生的交集 SELECT * FROM Student WHERE Sdept= CS‘ INTERSECT SELECT * FROM Student WHERE Sage=19; 本例实际上就是查询计算机科学系中年龄不大于19岁的学生 SELECT * FROM Student WHERE Sdept= CS AND Sage=19; * * 集合查询(续) 查询既选修了1号课程, 又选修了2号选修课程的学生 SELECT Sno FROM SC WHERE Cno= ‘1’ INTERSECT SELECT Sno FROM SC WHERE Cno=‘2’; 本例实际上是查询既选修了课程1又选修了课程2的学生 SELECT Sno FROM SC WHERE Cno=‘1’ AND Sno IN (SELECT Sno FROM SC WHERE Cno=‘2’); * * 集合查询(续) 查询计算机科学系的学生与年龄不大于19岁的学生的差集. SELECT * FROM Student WHERE Sdept=
文档评论(0)