eygle.com   eygle.com
eygle.com  
 

« Oracle HowTo:如何使用Oracle case函数 | Blog首页 | 回家纪事-之五 »

Oracle HowTo:如何使用Oracle的Decode函数进行多值判断

作者:eygle |【转载时请务必以超链接形式标明文章和作者信息及本声明
链接:
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.

By eygle on 2005-10-05 12:06 | Comments (0) | Posted to HowTo | Edit |Pageviews:

相关文章 随机文章
  • 如何判断一个字符串是否为数字或日期?
  • Oracle10g中SCN与TimeStamp的相互转换
  • 如何通过DB link进行远程过程或函数调用
  • 使用分析函数进行行列转换
  • Oracle HowTo:如何使用Oracle case函数
  • Oracle诊断案例-SGA与Swap之一
    Oracle初学者入门指南-系统与用户数据分离
    ZDNET《循序渐进Oracle》技术交流会
    Blog与六度分割理论
    Tools:使用Qslice观察消耗CPU资源的线程
    网上相关主题:
    Google

    留言 (0)

    发表留言:



    Remember Me?
    (输入验证码后方可评论,谢谢支持)



    CopyRight © 2004 eygle.com, All rights reserved.