DB2中进行sql除法运算结果为小数时显示0的解决方案

数据库
SELECT field1/field2 FROM TB;当 field1的数值 > field2的数值时,除法得出的结果是<1的,即0.xxxxxx,这个时候在DB2的环境下SELECT出来的值是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联合查询中的关键语法

 

责任编辑:段燃 来源: 互联网
相关推荐

2009-11-23 19:57:01

ibmdwDB2

2009-08-26 18:11:01

ibmdwDB2

2010-11-01 10:27:36

DB2数据库启动

2010-07-28 10:22:44

DB2 9.5

2011-03-14 15:47:34

DB2数据库代码

2011-03-22 09:45:59

IBMDB2数据库包的重绑定

2010-08-20 09:29:34

DB2文件系统已满

2009-07-29 17:39:57

ibmdwDB2

2010-08-12 10:43:36

DB2 SQL移植

2010-09-06 15:13:05

DB2

2010-11-04 15:39:40

DB2 SQL语句

2010-08-20 08:37:59

DB2创建外键

2010-09-30 16:00:40

DB2动态SQL

2010-11-02 11:43:11

DB2动态SQL

2011-05-27 15:51:44

DB2

2010-09-30 16:41:36

DB2隔离级别

2010-08-27 14:54:21

DB2批处理脚本

2010-11-11 11:25:45

SQL UPDATE语

2010-02-03 09:16:01

DB2

2010-08-18 09:09:15

DB2创建外键
点赞
收藏

51CTO技术栈公众号