Oracle查询预防解决分母为0的方法

本文通过两种函数方法解决介绍了sql查询中分母为0的预防处理方法,主要采用decode函数或case when。在oracle数据查询中,常计算百分比,百分比分母又常通过子查询获得,常遇到业务数据暂时没有的时候,此时分母为0,因此sql语句在涉及到除法运算时应当提前预防和处理分母为0的情况。

一、decode函数

1、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

2、NVL函数

NVL(expr1,expr2)

含义是:如果oracle第一个参数为空那么显示第二个参数的值,如果第一个参数的值不为空,则显示第一个参数本来的值。

3、示例

如下想要实现计算 percent = done_num/all_num,避免all_num没有数据(select count()时得来),并区分实际计算结果为0 的情况,当没有数据时返回NULL。

借助NVL函数和DECODE函数。

sql 复制代码
select 100*nvl(TABLE2.done_num,0)/decode(TABLE1.all_num,0,null,TABLE1.all_num) as percent from TABLE1,TABLE2

二、case when 语句

1、case when函数

CASE WHEN '表达式1' THEN '结果1'

WHEN '表达式2' THEN '结果2'

WHEN '表达式3' THEN '结果3'

ELSE '其他结果'

END

2、示例

如下想要实现计算 percent = done_num/all_num,避免all_num没有数据(select count()时得来),并区分实际计算结果为0 的情况,当没有数据时返回NULL。

sql 复制代码
select 100*IFNULL(TABLE2.done_num,0)/(CASE TABLE1.all_num
WHEN 0 THEN
NULL
ELSE
TABLE1.all_num
END
) as percent from TABLE1,TABLE2
相关推荐
HackTwoHub1 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t1 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK1 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)2 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
S1998_1997111609•X3 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
KmSH8umpK4 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式
BU摆烂会噶5 小时前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
l1t6 小时前
DeepSeek总结的DuckLake 入门
数据库
Joseph Cooper6 小时前
RAG 与 AI Agent:智能体真的需要检索增强生成吗?
数据库·人工智能·ai·agent·rag·上下文工程
light blue bird6 小时前
主子端台二分法任务汇总组件
前端·数据库·.net·桌面端winform