decode函数详解及使用实例(原创)

decode函数详解及使用实例(原创)

ID:36849428

大小:1.42 MB

页数:6页

时间:2019-05-16

decode函数详解及使用实例(原创)_第1页
decode函数详解及使用实例(原创)_第2页
decode函数详解及使用实例(原创)_第3页
decode函数详解及使用实例(原创)_第4页
decode函数详解及使用实例(原创)_第5页
资源描述:

《decode函数详解及使用实例(原创)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、decode函数实例详解及使用decode函数实例详解已知学生表:学号,姓名,性别。查询原始数据如下:select*fromt_student;S_IDS_NAMESEX1001a11002b21003c11004d1005e21006f3查询:selects.*,decode(s.sex,1,'男','其它')asnew_sexfromt_students;返回:S_IDS_NAMESEXNEW_SEX1001a1男1002b2其它1003c1男1004d其它1005e2其它1006f3其它解释:decod

2、e(s.sex,1,'男','其它')解释:如果s.sex的值为1,则返回“男”,否则返回“其它”。查询:selects.*,decode(s.sex,1,'男',2,'女','其它')asnew_sexfromt_students;S_IDS_NAMESEXNEW_SEX1001a1男1002b2女1003c1男1004d其它1005e2女1006f3其它解释:decode(s.sex,1,'男','其它')解释:如果s.sex的值为1,则返回“男”,如果s.sex的值为2,则返回“女”,否则返回“其它”。

3、小结decode语法:Decode(变量,值1,返回值a,值2,返回值b,,返回值n解释:如果变量=值1,则返回值a,变量=值2,则返回值b,,(配对出现),(最后一个)否则返回值n。即:decode中间的条件只要配对出现,则个数不限。直到最后有一个单独的返回值,表示不满足前面所有的条件时所返回的值。decode函数在统计中的使用:查询男女的人数通常是这样实现的:selectdecode(s.sex,1,'男',2,'女','其它')asnew_sex,count(*)xfromt_studentsgroup

4、bydecode(s.sex,1,'男',2,'女','其它')NEW_SEXX男2女2其它2但如果企业要求这样的格式,怎么办呢?男女其它221则必须这样做:1、首先通过decode函数将各种性别人员分开:selects.sex,decode(s.sex,1,1,null)as男,decode(s.sex,2,1,null)as女,decode(s.sex,3,1,null)as其它fromt_studentsSEX男女其它1121112131理解说明:decode(s.sex,1,1,null):表示如果性

5、别=1,则返回1(由于是计数, 只要返回一个非空值即可)。2、计数selectcount(decode(s.sex,1,1,null))as男,count(decode(s.sex,2,1,null))as女,count(decode(s.sex,3,1,null))as其它fromt_students说明:注意字段名为“男”,字段名称是没有用引号的。男女其它人数221示例脚本createtablet_student(s_idnumber(4)primarykey,s_namevarchar2(8),sexc

6、har(1) );insertintot_student(s_id,s_name,sex)values(1001,'a',1); insertintot_student(s_id,s_name,sex)values(1002,'b',2);insertintot_student(s_id,s_name,sex)values(1003,'c',1);insertintot_student(s_id,s_name,sex)values(1004,'d',null);insertintot_student(s_id

7、,s_name,sex)values(1005,'e',2);insertintot_student(s_id,s_name,sex)values(1006,'f',3);commit;SELECT*FROMt_student;男女其它221SELECT*FROMt_studentSELECT(SELECTCOUN(T*)FROMt_studentWHEREsex=1)AS男,(SELECTCOUN(T*)FROMt_studentWHERsEex=2)AS女,(SELECTCOUN(T*)FROMt_stu

8、dentWHERsEex=3ORsexISNULL)AS其它FROMdualSELECTt.*,decode(t.sex,1,1,NULL)男,decode(t.sex,2,1,NULL)女,decode(t.sex,1,NULL,2,NULL,1)其它FROMt_studentt--子查询SELECT'人数'AStitle,COUN(Tsex1)男,COUN(Tsex2)女,COUN(Tsex3)

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。