ORACLE decode

本文详细介绍了 Oracle 中 DECODE 函数的使用方法及其高级应用技巧,包括如何使用 DECODE 函数简化 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、Windows NT4.0+ORACLE 8.0.4

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

  ·含义解释:

  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

  · 使用方法:

  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)),


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


sql与oracle中有关case和decode的用法(行转列)及比较

引:

         为了举例说明,这里创建了一张成绩表,如下图所示:

        

比较:

         1、sql中,这两个函数我们仅能使用case,代码及结果如下:

   select name,
       case Subject
          when '语文' then 1
          when '数学' then 2
          when '英语' then 3   --else 3
       end  as '科目代码'
   from Results

  

   同样的,我们可以用case实现行转列,代码及结果如下:

   select Name,
            sum(case when Subject='语文' then Result end) '语文',
            sum(case when Subject='数学' then Result end) '数学',
            sum(case when Subject='英语' then Result end) '英语'
   from Results
   group by Name

  

  

         2、但是,在oracle中,这两个函数我们都可以使用,代码及结果如下:

             decode用法:select Name,decode(Subject,'语文',1,'数学',2,'英语',3) 科目代码 from results;

                               select Name,decode(Subject,'语文',1,'数学',2,3) 科目代码 from Results;

                 case用法:

  select name,
       case
          when Subject='语文' then 1
          when Subject='数学' then 2
          when Subject='英语' then 3  --else 3
       end  as 科目代码
  from Results;

  这两种方法均能达到同样的结果:

 

  同样的,我们可以使用这两个函数实现行转列,代码及结果如下:

  decode:

select
   Name,
   sum(decode(Subject,'语文',Result,0)) 语文,
   sum(decode(Subject,'数学',Result,0)) 数学,
   sum(decode(Subject,'英语',Result,0)) 英语
from Results
group by Name;

     case:

select
   Name,
   sum((case when Subject='语文' then Result else 0 end)) 语文,
   sum((case when Subject='数学' then Result else 0 end)) 数学,
   sum((case when Subject='英语' then Result else 0 end)) 英语
from Results
group by Name;

 

数据库表与行转列的中间结果(想想还是也附上)

oracle中:

select
   Name,
   decode(Subject,'语文',Result,0) 语文,
   decode(Subject,'数学',Result,0) 数学,
   decode(Subject,'英语',Result,0) 英语
from Results;

select
   Name,
   (case when Subject='语文' then Result else 0 end) 语文,
   (case when Subject='数学' then Result else 0 end) 数学,
   (case when Subject='英语' then Result else 0 end) 英语
from Results; 

结果如下:

以上内容,不对的地方请指正。此文仅想抛砖引玉...

(续)

SQL2000中动态SQL

declare @sql varchar(8000)
set @sql = 'select name '
select @sql = @sql + ' , sum(case Subject when '+ char(39) + Subject + char(39) +' then Result else 0 end) [' + Subject + ']'
from (select distinct Subject from results) as a
set @sql = @sql + ' from results group by name'
exec(@sql)

 

SQL2005中动态SQL

declare @sql varchar(8000)
select @sql = isnull(@sql + '],[' , '') + Subject from Results group by Subject
set @sql = '[' + @sql + ']'
exec ('select * from  Results pivot (max(result) for subject in (' + @sql + ')) b')

 


### 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` 形式书写复杂控制流结构以增强程序可维护性以及提升团队协作效率。 --- 问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值