Oracle Decode

本文介绍了ORACLE PL/SQL中的decode()函数,该函数目前仅ORACLE公司的SQL提供。文中说明了其用途,如给职员加工资时可省略流控制语句;介绍了语法,还给出使用技巧,包括比较大小、表和视图结构转化等,并补充了语法结构和简单测试示例。
decode()函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能。
 

      DECODE函数是ORACLE PL/SQL是功能强大的函数之一,目前还只有ORACLE公司的SQL提供了此函数,其他数据库厂商的SQL实现还没有此功能。DECODE有什么用途 呢? 先构造一个例子,假设我们想给智星职员加工资,其标准是:工资在8000元以下的将加20%;工资在8000元以上的加15%,通常的做法是,先选出记录 中的工资字段值? select salary into var-salary from employee,然后对变量var-salary用if-then-else或choose case之类的流控制语句进行判断。 如果用DECODE函数,那么我们就可以把这些流控制语句省略,通过SQL语句就可以直接完成。如下:select decode(sign(salary - 8000),1,salary*1.15,-1,salary*1.2,salary from employee 是不是很简洁? DECODE的语法:DECODE(value,if1,then1,if2,then2,if3,then3,...,else),表示如果value 等于if1时,DECODE函数的结果返回then1,...,如果不等于任何一个if值,则返回else。初看一下,DECODE 只能做等于测试,但刚才也看到了,我们通过一些函数或计算替代value,是可以使DECODE函数具备大于、小于或等于功能。

DECODE(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

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

  decode()函数使用技巧

  ·软件环境:

  1、Windows NT4.0+ORACLE 8.0.4

  2、ORACLE安装路径为:C:/ORANT

  · 使用方法:

  1、比较大小

  select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值

  sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1

  例如:

  变量1=10,变量2=20

  则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。

  2、表、视图结构转化

  现有一个商品销售表sale,表结构为:

  month    char(6)      --月份

  sell    number(10,2)   --月销售金额

  现有数据为:

  200001  1000

  200002  1100

  200003  1200

  200004  1300

  200005  1400

  200006  1500

  200007  1600

  200101  1100

  200202  1200

  200301  1300

  想要转化为以下结构的数据:

  year   char(4)      --年份

  month1  number(10,2)   --1月销售金额

  month2  number(10,2)   --2月销售金额

  month3  number(10,2)   --3月销售金额

  month4  number(10,2)   --4月销售金额

  month5  number(10,2)   --5月销售金额

  month6  number(10,2)   --6月销售金额

  month7  number(10,2)   --7月销售金额

  month8  number(10,2)   --8月销售金额

  month9  number(10,2)   --9月销售金额

  month10  number(10,2)   --10月销售金额

  month11  number(10,2)   --11月销售金额

  month12  number(10,2)   --12月销售金额

  结构转化的SQL语句为:

  create or replace view

  v_sale(year,month1,month2,month3,month4,month5,month6,month7,month8,month9,month10,month11,month12)

  as

  select

  substrb(month,1,4),

  sum(decode(substrb(month,5,2),'01',sell,0)),

  sum(decode(substrb(month,5,2),'02',sell,0)),

  sum(decode(substrb(month,5,2),'03',sell,0)),

  sum(decode(substrb(month,5,2),'04',sell,0)),

 

======================================================

补充1:

有学生成绩表student,现在要用decode函数实现以下几个功能:成绩>85,显示优秀;>70显示良好;>60及格;否则是不及格。
假设student的编号为id,成绩为score,那么:
select id, decode(sign(score-85),1,'优秀',0,'优秀',-1, 
decode(sign(score-70),1,'良好',0,'良好',-1, 
decode(sign(score-60),1,'及格',0,'及格',-1,'不及格'))) 
from student;
======================================================
补充2:

Decode函数的语法结构如下:
decode (expression, search_1, result_1)
decode (expression, search_1, result_1, search_2, result_2)
decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n)

decode (expression, search_1, result_1, default)
decode (expression, search_1, result_1, search_2, result_2, default)
decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)

decode函数比较表达式和搜索字,如果匹配,返回结果;如果不匹配,返回default值;如果未定义default值,则返回空值。
以下是一个简单测试,用于说明Decode函数的用法:
SQL> create table t as select username,default_tablespace,lock_date from dba_users;

Table created.

SQL> select * from t;

USERNAME                        DEFAULT_TABLESPACE              LOCK_DATE
------------------------------ ------------------------------ ---------
SYS                             SYSTEM
SYSTEM                          SYSTEM
OUTLN                           SYSTEM
CSMIG                           SYSTEM
SCOTT                           SYSTEM
EYGLE                           USERS
DBSNMP                          SYSTEM
WMSYS                           SYSTEM                          20-OCT-04

8 rows selected.


SQL> select username,decode(lock_date,null,'unlocked','locked') status from t;

USERNAME                        STATUS
------------------------------ --------
SYS                             unlocked
SYSTEM                          unlocked
OUTLN                           unlocked
CSMIG                           unlocked
SCOTT                           unlocked
EYGLE                           unlocked
DBSNMP                          unlocked
WMSYS                           locked

8 rows selected.

SQL> select username,decode(lock_date,null,'unlocked') status from t;

USERNAME                        STATUS
------------------------------ --------
SYS                             unlocked
SYSTEM                          unlocked
OUTLN                           unlocked
CSMIG                           unlocked
SCOTT                           unlocked
EYGLE                           unlocked
DBSNMP                          unlocked
WMSYS

8 rows selected.

转载于:https://www.cnblogs.com/harryliu/archive/2013/02/04/2891449.html

### Oracle DECODE 函数详解 #### 什么是DECODE函数? `DECODE` 是 Oracle 数据库中的一个条件判断函数,类似于编程语言中的 `if-else` 或者 `switch-case` 结构。它可以根据输入值与多个可能值的匹配情况来返回不同的结果。 其基本语法如下: ```sql DECODE(expression, search1, result1 [, search2, result2 ... ] [, default]) ``` - **expression**: 被评估的目标值。 - **searchN**: 表达式要与其比较的一个或多个值。 - **resultN**: 如果 expression 和某个 search 值匹配,则返回对应的 result 值。 - **default**: 当没有任何 match 发生时,默认返回此值(可选)。如果没有提供默认值且无匹配项,则返回 NULL[^1]。 #### 示例解析 ##### 单独使用DECODE函数 下面是一个简单的例子展示如何利用 `DECODE` 来替代多分支逻辑: 假设有一个表名为 `SYS_USER` 的表格,其中包含字段 `login_name` 。我们希望基于特定用户名显示自定义消息: ```sql SELECT id, login_name AS "账号", DECODE(login_name, 'test', '我是第一个', 'mtest', '我是就是我', '哈哈') AS "输出内容" FROM SYS_USER WHERE login_name LIKE '%test%'; ``` 在这个查询里,“test”的记录会得到“我是第一个”,而“mtest”则获得“我是就是我”。对于既不是'test'也不是'mtest'的情况,由于没有指定其他具体的结果映射关系,因此这些都将统一给出字符串"哈哈"[^2]. ##### 配合SIGN()函数使用 另一个常见场景是将 `DECODE` 同数学运算结合起来完成更复杂的业务需求。比如通过计算两个数之间的差并判定正负号来进行分类处理: ```sql SELECT DECODE(SIGN(5 - 6), 1, 'Is Positive', -1, 'Is Negative', 'Is Zero') AS Result; ``` 这里先调用了内置函数 `SIGN()` 对表达式 `(5 - 6)` 进行求解得出 `-1`, 接着再由外层包裹它的 `DECODE` 判断最终呈现为 “Is Negative”。 值得注意的是,在现代 SQL 实践中推荐更多采用标准 ANSI SQL 提供的功能强大的 CASE WHEN 构造代替 DECODE ,因为后者具有更好的跨平台兼容性和语义清晰度 : ```sql SELECT CASE SIGN(5 - 6) WHEN 1 THEN 'Is Positive' WHEN -1 THEN 'Is Negative' ELSE 'Is Zero' END AS Result; ``` 以上两种写法效果完全一致,但后者更加直观易读 [^3]。 #### 特殊情况考虑 有时可能会遇到某些特殊状况下的行为需要注意,例如当所有选项均不满足时的行为或者存在 null 输入的情形等。请看以下实例演示: ```sql -- 此处即使 value 不等于任何已列明 case ,也不会报错而是正常返回设定好的缺省值'default_value'. SELECT DECODE(value, 1, 'one', 2, 'two', 'default_value'); -- 若未设置最后那个参数作为 fallback option 并且也没有找到相符项目的话,那么整个表达式的产出将是 NULL. SELECT DECODE(NULL, '', 'empty string', 'non-empty'); ``` 上述代码片段展示了即便传入 null 给 decode 第一参量位置上也依然能够按照预期运作良好,并且清楚表明了如果不加额外配置的话缺失情形下产生的后果是什么样的 [^3]。 ### 总结 综上所述,虽然 `DECODE` 功能强大简单好用,但在实际开发过程中还是建议优先选用标准化程度更高的 `CASE...WHEN...THEN...END` 形式书写复杂控制流结构以增强程序可维护性以及提升团队协作效率。 --- 问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值