DECODE()函数用法
效果:将输入数值与函数中的参数列表相比较,根据输入值回来一个对应值。函数的参数列表是由若干数值及其对应成果值组成的若干序偶形式。当然,假设未能与任何一个实参序偶匹配成功,则函数也有默许的回来值。差异于SQL的其它函数,DECODE函数还能识别和操作空值。
语法:DECODE(control_value,value1,result1[,value2,result2…][,default_result]);
control_value试图处理的数值。DECODE函数将该数值与后边的一系列的偶序相比较,以决议回来值。value1是一组成序偶的数值。假设输入数值与之匹配成功,则相应的成果将被回来。对应一个空的回来值,能够运用要害字NULL于之对应result1是一组成序偶的成果值。default_result未能与任何一个值匹配时,函数回来的默许值。
例如:selectdecode(x,1,‘xis1’,2,‘xis2’,‘others’)fromdual当x等于1时,则回来‘xis1’。当x等于2时,则回来‘xis2’。否则,回来others’。需要,比较2个值的时分,能够合作SIGN()函数一同运用。SELECTDECODE(SIGN(5-6),1’IsPositive’,-1,’IsNagative’,’IsZero’)相同,也能够用CASE实现:SELECTCASESIGN(5-6)WHEN1THEN’IsPositive’WHEN-1THEN’IsNagative’ELSE’IsZero’ENDFROMDUAL此外,还能够在Orderby中运用Decode。例如:表table_subject,有subject_name列。要求按照:语、数、外的顺序进行排序。这时,就能够非常轻松的运用Decode完结要求了。
select*fromtable_subjectorderbydecode(subject_name,’语文’,1,’数学’,2,,’外语’,3)
将一切的成果悉数写出
select*fromclassest
数据为
1一班NUM_1
2二班NUM_2
3三班NUM_3
4四班NUM_4
selectt.*fromclassestorderbydecode(t.classnum,’NUM_1′,4,’NUM_2′,3,’NUM_3′,1);
3三班NUM_3
2二班NUM_2
1一班NUM_1
4四班NUM_4
必须将一切的成果写出
oracledecode函数用法
Oracle中decode函数用法
含义解释:
decode(条件,值1,返回值1,值2,返回值2,…值n,返回值n,缺省值)
该函数的含义如下:
IF条件=值1THEN
RETURN(翻译值1)
ELSIF条件=值2THEN
RETURN(翻译值2)
……
ELSIF条件=值nTHEN
RETURN(翻译值n)
ELSE
RETURN(缺省值)
ENDIF
decode(字段或字段的运算,值1,值2,值3)
这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回值3
当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多
使用方法:
1、比较大小
selectdecode(sign(变量1-变量2),-1,变量1,变量2)fromdual;–取较小值
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
例如:
变量1=10,变量2=20
则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。
2、此函数用在SQL语句中,功能介绍如下:
Decode函数与一系列嵌套的IF-THEN-ELSE语句相似。base_exp与compare1,compare2等等依次进行比较。如果base_exp和第i个compare项匹配,就返回第i个对应的value。如果base_exp与任何的compare值都不匹配,则返回default。每个compare值顺次求值,如果发现一个匹配,则剩下的compare值(如果还有的话)就都不再求值。一个为NULL的base_exp被认为和NULLcompare值等价。如果需要的话,每一个compare值都被转换成和第一个compare值相同的数据类型,这个数据类型也是返回值的类型。
Decode函数在实际开发中非常的有用
结合Lpad函数,如何使主键的值自动加1并在前面补0
selectLPAD(decode(count(记录编号),0,1,max(to_number(记录编号)+1)),14,’0′)记录编号fromtetdmis
eg:
selectdecode(dir,1,0,1)froma1_interval
dir的值是1变为0,是0则变为1
比如我要查询某班男生和女生的数量分别是多少?
通常我们这么写:
selectcount(*)from表where性别=男;
selectcount(*)from表where性别=女;
要想显示到一起还要union一下,太麻烦了
用decode呢,只需要一句话
selectdecode(性别,男,1,0),decode(性别,女,1,0)from表
3,orderby对字符列进行特定的排序
大家还可以在Orderby中使用Decode。
例:表table_subject,有subject_name列。要求按照:语、数、外的顺序进行排序。这时,就可以非常轻松的使用Decode完成要求了。
select*fromtable_subjectorderbydecode(subject_name,’语文’,1,’数学’,2,,’外语’,3
S
1、IT大王遵守相关法律法规,由于本站资源全部来源于网络程序/投稿,故资源量太大无法一一准确核实资源侵权的真实性;
2、出于传递信息之目的,故IT大王可能会误刊发损害或影响您的合法权益,请您积极与我们联系处理(所有内容不代表本站观点与立场);
3、因时间、精力有限,我们无法一一核实每一条消息的真实性,但我们会在发布之前尽最大努力来核实这些信息;
4、无论出于何种目的要求本站删除内容,您均需要提供根据国家版权局发布的示范格式
《要求删除或断开链接侵权网络内容的通知》:https://itdw.cn/ziliao/sfgs.pdf,
国家知识产权局《要求删除或断开链接侵权网络内容的通知》填写说明: http://www.ncac.gov.cn/chinacopyright/contents/12227/342400.shtml
未按照国家知识产权局格式通知一律不予处理;请按照此通知格式填写发至本站的邮箱 wl6@163.com