- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
oracle比较decode(case when) 、4种去重---和去重中的统计函数
oracle比较decode/case when 、4种去重和去重中的统计函数
一: decode 和 case when
decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)
decode函数比较表达式和搜索字,如果匹配,返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。
select username,decode(lock_date,null,unlocked,locked) status from t;
----------------如果lock_date是null就返回unlocked 如果不是null就返回locked
select username,decode(lock_date,null,unlocked) status from t;
----------------如果lock_date是null就返回unlocked 否则是空(因为没有定义)
例如有个学生表...... 行转列-------
create table score2(
name varchar2(10),Language number(3),Math number(3),English number(3));
insert into score2 values(Zhang,80,67,95);insert into score2 values(Li,79,84,62);insert into score2(name,Language) values(Chen,88);commit;
Select * from score2; 显示成报表的格式.......
select name,
sum(decode(subject,Language, grade,0)) Language,
sum(decode(subject,Math, grade,0)) Math,
sum(decode(subject,English, grade,0)) English
from score
group by name;
NAME Language Math English
-------------------- ---------- ---------- ----------
Zhang 80 92 76
Wang 73 0 0
Li 81 95 50
第二列,如果 subject=Language,那么就显示成绩,否则显示为0
第三列,如果 subject=Math,那么就显示成绩,否则显示为0
第四列,如果 subject=English,那么就显示成绩,否则显示为0
Case when
Case [selector] ---selector可以不设置
When id=1 THEN ‘id是1’;
ELSE ‘没有id值’;END CASE; ----如果ID=1 就显示id是1 否则显示没有id值
~~~~~上面用case when显示.................select , sum( case when t.subject = Language then t.grade else 0 end ) dd, sum( case when t.subject = Math then t.grade else 0 end ) Math, sum( case when t.subject = English then t.grade else 0 end ) English from score t group by ;
二:去重的4中方法
create table test (c1 int ,c2 varchar2(10));
insert into test values (1,Smith);
insert into test values (1,Smith);
insert into test values (2,John);
您可能关注的文档
最近下载
- 提高择期手术患者术前准备完善率医院护理品管圈QCC成果汇报PPT(完整版本易修改).pptx VIP
- B-65522CM_01-αi-B βi-B 伺服电机规格.pdf VIP
- 采购部员工年终总结.pptx VIP
- 《老年人能力评估从业人员培训指南》.pdf
- 二年级道德与法治上册-全册教案-新人教版.pdf VIP
- 投资项目风险因素识别核对表.docx
- CAAC无人机理论考试题库(2025修订版)含答案.docx VIP
- DB11∕T 512-2024 建筑装饰工程石材应用技术规程.pdf
- Unit1 单元整体教学设计-小学英语五年级上册(人教PEP版).docx VIP
- CAAC无人机理论考试题库(2025修订版)含答案.docx VIP
文档评论(0)