志在指尖
用双手敲打未来

oracle decode(decode函数在mysql中怎么用)

oracledecode
MySQLdecode()的同等完成
在Oracle中运用decode办法能够轻松完成代码和值之间的转换,可是在MySQL中该如何完成类似功用呢?
MySQL中没有直接的办法能够运用,可是我们能够经过下面两种办法来完成:
1.casewhenthen
如:Selecttitle,caseEmergencywhen1then’紧迫’else’一般’Endasemergencyfromalready_sign
2.if
如:selecta.title,if(a.Emergency=1,’紧迫’,’一般’)emergencyfromalready_signa
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)
走下一步,留下走过的脚印。期望越走越远,走的更稳,更好!
decode函数在mysql中怎么用
1、运用decode判断字符串是否相同
decode(value,if1,then1,if2,then2,if3,then3,…,else)
含义为
IF条件=值1THEN
RETURN(value1)
ELSIF条件=值2THEN
RETURN(value2)
……
ELSIF条件=值nTHEN
RETURN(value3)
ELSE
RETURN(default)
ENDIF
示例:
2、运用decode比较巨细
selectdecode(sign(var1-var2),-1,var1,var2)fromdual
sign()函数根据某个值是0、正数仍是负数,分别回来0、1、-1
示例:
3、运用decode函数分段
薪酬大于5000为高薪,薪酬介于3000到5000为中等,小于3000为低薪
示例:
4、利用decode完成表或许视图的行列转化
5、运用decode函数来运用表达式来查找字符串
decode(expression,search_1,result_1,search_2,result_2,….,search_n,result_n,default)
decode函数比较表达式和查找字,假如匹配,回来成果;假如不匹配,回来default值;假如未定义default值,则回来空值。

未经允许不得转载:IT技术网站 » oracle decode(decode函数在mysql中怎么用)
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!

 

志在指尖 用双手敲打未来

登录/注册IT技术大全

热门IT技术

C#基础入门   SQL server数据库   系统SEO学习教程   WordPress小技巧   WordPress插件   脚本与源码下载