Oracle中的逻辑判断(nvl、decode和case when)

          刚结束一个项目,感觉在数据库查询时逻辑判断用的特别多,用到了nvl、decode和case when,下面讲一下这几种逻辑判断方式的异同,自己整理的,可能有些地方说错,希望大家提出来:


          NVL(a,b)就是判断a是否是NULL,如果不是返回a的值,如果是返回b的值 通过查询获得某个字段的合计值,如果这个值为null将给出一个预设的默认值


          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 都可以是函数或计算表达式。

         

           case when语句类似于C#语法中的if else语法,比如:select case when id > 0 then 1 else 0 end as flag from table1,这句sql就表示 筛选所有table1中的记录,当id大于0时,新的flag列就为1,否则,flag列为0


你可能感兴趣的:(数据库)