微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Oracle CASE短路不能分组工作

我在 documentation of case statment中发现它使用了短路:

Oracle Database uses short-circuit evaluation. That is,for a simple
CASE expression,the database evaluates each comparison_expr value
only before comparing it to expr,rather than evaluating all
comparison_expr values before comparing any of them with expr.
Consequently,Oracle never evaluates a comparison_expr if a prevIoUs
comparison_expr is equal to expr. For a searched CASE expression,the
database evaluates each condition to determine whether it is true,and
never evaluates a condition if the prevIoUs condition was true.

但是以下sql返回的除数等于零:

WITH data AS (SELECT 1 AS cond,10 AS num,0 AS div FROM DUAL)
SELECT
  CASE WHEN cond = 2 THEN (CASE WHEN MAX(div) = 0 THEN 0 ELSE SUM(num / div) END)
       ELSE -1
  END AS result
FROM data
GROUP BY cond

任何避免除数的解决方案都等于零误差?

编辑

查询工作正常:

WITH data AS (SELECT 1 AS cond,0 AS div FROM DUAL)
SELECT
  CASE WHEN cond = 2 THEN (CASE WHEN MAX(div) = 0 THEN 0 ELSE 1 END)
       ELSE -1
  END AS result
FROM data
GROUP BY cond
使用
CASE WHEN cond = 2 
     THEN SUM(case when div = 0 then 0 else num / div end)
     ELSE -1
END

原文地址:https://www.jb51.cc/oracle/205594.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐