Oracle条件分支查询

摘要:
事实上,Oracle的条件分支查询与Java的条件分支语法没有太大区别,只是Java有一个switch关键字。当然,这种逻辑也可以写在代码中。

  Oracle的条件分支查询其实跟java的条件分支语法没啥太大的区别,只不过java多了一个switch关键字而已。看例子:

SQL> SELECT CASE WHEN SUM(t1.TOTALTICKET) is null THEN 0 ELSE SUM(t1.TOTALTICKET) END  totalTicket
  2  FROM T_WLF_CUSTOM_RECORD t1 WHERE t1.ACTIVITYID=4001
  3  AND t1.INVITERMSISDN='16682318566';
 
TOTALTICKET
-----------
      10086

  这里针对金额的累计和做了一个处理,如果总数取到的是null,则转为0,否则按原总数返回。当然这段逻辑也可以在代码里写。我们再看一个例子:

SQL> select LASTMODIFYER,count(CASE WHEN type=1 THEN 1 ELSE null END) 邀请人黑名单, count(CASE WHEN type=2 THEN 1 ELSE null END) 排行榜黑名单 from t_wlf_blacklist where hasdelete is null group by LASTMODIFYER;
 
LASTMODIFYER           邀请人黑名单       排行榜黑名单
---------------- ------------ ------------
admin02                     1            0
admin01                  9888          132

  上面的查询可以减少我们一次select操作。

免责声明:文章转载自《Oracle条件分支查询》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇ubuntu基本命令基于R语言股票市场收益的统计可视化分析下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

MySQL行列转换

实际应用中,会遇到需要把表的某些行转换成列,或者把列转换成行的情况。比如一张表在数据库中是这样的:  图1 但是,需要的结果可能是这样:  图2 这个时候就得行列转换了。 1.行转列的几种方法 1.1 case ...  when  ... then ... else ... end select uname,uid, -- 正常查询的字段 sum( ca...

使用log4j无法输出日志

前段时间在项目的过程中使用log4j来输出日志,但是在一个项目里我明明已经在src/main/resource目录下创建了log4j.properties。具体配置如下: log4j.rootLogger = INFO, stdout log4j.category.appcloud.approuter = INFO log4j.category.appcl...

[java]创建一个默认TreeMap() key为什么不能为null

 本文版权归 远方的风lyh和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作。 先看一下 TreeMap 的 put(K key, V value) public TreeMap() { comparator = null;} public V put(K key, V value) { Entry<K,V...

阿里人脸识别接口

最近研究了一下阿里的人脸识别功能,只是调用阿里提供的接口返回数据给我们就OK了。详细文档可参考阿里的api  阿里人脸识别api 人脸比对的方法 直接上代码吧: 1 package com.guoxin.common.test; 2 3 import sun.misc.BASE64Encoder; 4 import javax.cryp...

delphi中nil、null、UnAssigned区别

nil:空指针,空地址,对象也是指针,所以可以object:=nil;null:null是一个未定义值的变量,既不是0也不代表空字符串,它是未定义的。http://www.delphibasics.co.uk/RTL.asp?Name=Null判断对象为不为空用ifassigned(object)then和ifobject=nilthen都一样可以。 ni...

mybatis学习(九)(调用存储过程(内含游标))

相信oracle的存储过程,大家都不陌生,有时候的确需要它来进行一些特殊的操作。当一个存储过程要返回一个大的数据集的时候,就需要游标在存储过程中使用。当查询结果出来后,又如何在mybatis中将这些数据注入到相应的对象中呢?在mybatis中要用到resultMap。 实例:运用储存过程输出dept表中的所有信息。 sql语句如下: --创建一个包,在这个...