DB2中进行sql除法运算结果为小数时显示0的解决方案
创始人
2024-07-13 09:51:04
0

在进行sql除法运算时,在DB2的环境下SELECT出来的值是0,这应该如何处理呢?本文将为您介绍DB2中进行sql除法运算结果为小数时显示0问题的两种解决方法,供您参考。

SELECT field1/field2 FROM TB;
当 field1的数值 > field2的数值时,除法得出的结果是<1的,即0.xxxxxx
这个时候在DB2的环境下SELECT出来的值是0
这个有两个解决方法

方法1:
DB CFG的一个参数MIN_DEC_DIV_3,这个参数在GET DB CFG FOR DB中并不会列出,但却可以修改。
数据库配置参数MIN_DEC_DIV_3会更改涉及小数的十进制算术运算的结果小数位。
默认值为No,则小数位计算为 31-p+s-s'。
如果设置为Yes,则小数位计算为 MAX(3, 31-p+s-s')。
这会导致十进制小数部分始终至少具有3位的小数位。精度始终为31。

这个方法貌似需要通过DBA对数据库进行设置,不太靠谱儿,有另外一种方法可以曲线救国,登场:

将sql语句修改为:

View Code SQL1
 SELECT CAST(field1 AS DOUBLE)/field2 FROM TB;

就是先把field1转换成DOUBLE类型的,这样计算出来的就会得出小数点了,会显示出0.xxxxxx

接下来,需要对得出的小数点位数进行约束,那就用四舍五入吧,

View Code SQL1
 SELECT ROUND(CAST(field1 AS DOUBLE)/field2, 2) FROM TB;

这个意思就是说四舍五入,保留两位小数点

但是如果field1或者field2有一个字段为NULL的话,那么结果为NULL,这个时候根据逻辑需要进行如下的一个操作,
如果数据列的值为NULL,将其设置为0,那么sql就要这么写

View Code SQL1
 SELECT ROUND(COALESCE(CAST(field1 AS DOUBLE), 0)/field2, 2) FROM TB;

COALESCE这个函数系统的用法如下:
a. 输入参数为字符类型,且允许为空的,可以使用COALESCE(inputParameter,”)把NULL转换成”;
b. 输入类型为整型,且允许为空的,可以使用COALESCE(inputParameter,0),把空转换成0;
c. 输入参数为字符类型,且是非空非空格的,可以使用COALESCE(inputParameter,”)把NULL转换成”,然后判断函数返回值是否为”;
d. 输入类型为整型,且是非空的,不需要使用COALESCE函数,直接使用IS NULL进行非空判断。
 

 

 

【编辑推荐】

用SQL游标遍历循环数据的方法

sql中while语句多层循环实例

For循环中执行SQL查询的讨论

sql中inner join(等值连接)的语法

SQL中关于join联合查询中的关键语法

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
规避非法攻击 用好路由器远程管... 单位在市区不同位置设立了科技服务点,每一个服务点的员工都通过宽带路由器进行共享上网,和单位网络保持联...
范例解读VB.NET获取环境变... VB.NET编程语言的使用范围非常广泛,可以帮助开发人员处理各种程序中的需求,而且还能对移动设备进行...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...