decodesql
‘壹’ sql decode函数里面有多个值怎么办
1, deocde 与 case when 的作用相同,用于不同条件分支的不同处理。于case when 相比只是用法不同。同样可以嵌套和满足多个值。
2,多个值
decode(name, 'Wang', '001', 'Li', '002', '003')
相当于
case
when name = 'Wang'
then '001'
when name = 'Li'
then '002'
else '003'
end
3, 嵌套
decode(name, 'Wang', decode(sno, '001', 'Yes', ''), 'Li', decode(sno,'002','Yes',''), decode(sno, '003','Yes',''))
相当于
case
when name = 'Wang'
then case
when sno='001'
then 'Yes'
else ''
end
when name='Li'
then case
when sno='002'
then 'Yes'
else ''
end
else case
when sno='003'
then 'Yes'
else ''
end
end
‘贰’ 请问SQL中decode函数的用法
DECODE函数是ORACLE PL/SQL是功能强大的函数之一,还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能。
DECODE函数,是ORACLE公司的SQL软件ORACLE PL/SQL所提供的特有函数计算方式,以其简洁的运算方式,可控的数据模型和灵活的格式转换而闻名。
(2)decodesql扩展阅读:
DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )
Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。
需要注意的是,这里的if、then及else 都可以是函数或计算表达式。
‘叁’ sql中怎么实现decode的功能
ORACLE的decode功能绝对不如case那么灵活﹐
oracle8i以上版本都提供了case语法﹐
decode的实现是commandline的方式传入,SQL没有这种实现﹐当然可以摭展存储
过程的方式实现﹐用DELPHI写DLL﹐加载到
企业管理器
中。
‘肆’ sql语句中decode函数怎么加条件
DECODE 是 判断 等于/不等于的情况。
判断小于的, 用 CASE WHEN
例如:
CASE
WHEN 数学成绩 < 60 THEN '不及格'
ELSE '及格'
END
‘伍’ sql语句中,decode和case when语句的区别有哪些
case when 写起来更长但是更灵活,比如可以case when 列1>列2 ,而decode要实现这个功能要借用SIGN函数,因为DECODE只能判断具体值不能判断条件格式,decode(sign(列1-列2),1,‘’)效果等同如上,其他的基本等同。
还有decode有一个灵活的应用就是order by , order by decode(列1,字符,1,字符2,2)可以进行灵活的排序。
‘陆’ SQL中 decode()函数简介
DECODE函数,是ORACLE公司的SQL软件ORACLE
PL/SQL所提供的特有函数计算方式,以其简洁的运算方式,可控的数据模型和灵活的格式转换而闻名。
今天看别人的SQL时看这里面还有decode()函数,以前从来没接触到,上网查了一下,还挺好用的一个函数,写下来希望对朋友们有帮助哈!
decode()函数简介:
主要作用:将查询结果翻译成其他值(即以其他形式表现出来,以下举例说明);
使用方法:
Select
decode(columnname,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)
From
talbename
Where
…
其中columnname为要选择的table中所定义的column,
·含义解释:
decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)的理解如下:
if
(条件==值1)
then
return(翻译值1)
elsif
(条件==值2)
then
return(翻译值2)
......
elsif
(条件==值n)
then
return(翻译值n)
else
return(缺省值)
end
if
注:其中缺省值可以是你要选择的column
name
本身,也可以是你想定义的其他值,比如Other等;
举例说明:
现定义一table名为output,其中定义两个column分别为monthid(var型)和sale(number型),若sale值=1000时翻译为D,=2000时翻译为C,=3000时翻译为B,=4000时翻译为A,如是其他值则翻译为Other;
SQL如下:
Select
monthid
,
decode
(sale,1000,'D',2000,'C',3000,'B',4000,'A','Other')
sale
from
output
特殊情况:
若只与一个值进行比较
Select
monthid
,decode(sale,
NULL,‘---',sale)
sale
from
output
另:decode中可使用其他函数,如nvl函数或sign()函数等;
NVL(EXPR1,EXPR2)
若EXPR1是NULL,则返回EXPR2,否则返回EXPR1.
SELECT
NAME,NVL(TO_CHAR(COMM),'NOT
APPLICATION')
FROM
TABLE1;
如果用到decode函数中就是
select
monthid,decode(nvl(sale,6000),6000,'NG','OK')
from
output
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1,
如果取较小值就是
select
monthid,decode(sign(sale-6000),-1,sale,6000)
from
output,即达到取较小值的目的。
小结:
作用:将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,假如未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。
区别于SQL的其它函数,DECODE函数还能识别和操作空值。
语法:DECODE(control_value,value1,result1[,value2,result2…][,default_result]);
control
_value试图处理的数值。DECODE函数将该数值与后面的一系列的偶序相比较,以决定返回值。
value1是一组成序偶的数值。假如输入数值与之匹配成功,则相应的结果将被返回。对应一个空的返回值,可以使用要害字NULL于之对应
result1
是一组成序偶的结果值。
default_result
未能与任何一个值匹配时,函数返回的默认值。
‘柒’ decode的表达式能否为SQL语句
可以的。只是只能出现在select之后。
例:SQL> select decode('1','1','select * fro emp') from al;
DECODE('1','1','SELECT*FROEMP'
------------------------------
select * fro emp
如果控制判断不需要decode,改用nvl就可以了。
例如:SQL> select nvl('','Select * from emp') from al;
NVL('','SELECT*FROMEMP')
------------------------
Select * from emp
‘捌’ sql语句 encode和decode的作用与区别。 求大佬解答_(:з”∠)_
ENCODE(str,pass_str)
使用pass_str作为口令加密str。为了解密结果,使用DECODE()。结果是一个二进制字符串,如果你想要在列中保存它,使用一个BLOB列类型。
DECODE(crypt_str,pass_str)
使用pass_str作为口令解密加密的字符串crypt_str。crypt_str应该是一个由ENCODE()返回的字符串。
祝好运,望采纳
‘玖’ oracle decode函数 Sql 查询语句
select*from(selectadate,iswin,count(1)ascfromtbgroupbyadate,iswin)pPivot(max(c)foriswinin(胜,负))aspvtorderbyadate
‘拾’ 请教sql decode函数的一个简单用法
首先decode函数是Oracle独有的判断函数!
//其实就是一个简单的判断函数,比如字段的值为a
decode(字段,'a','输出是a','是a','输出是b','否则输出都不是');
//下面我拿EMP表的SCOTT来示例代码:
SELECT
DECODE(ename,'是SCOTT','Yes','不是SCOTT','No','都不是')
FROMemp
WHEREename=UPPER('scott');