sql 除法保留小数 算出分子为0的情况

在一个除法算式里,那个数不能为0?
除数不能为零(即分母)
为您推荐:
其他类似问题
除数不能为零。也就是除号后面的数不能为零啊。
扫描下载二维码DB2中进行sql除法运算结果为小数时显示0的解决方案
DB2中进行sql除法运算结果为小数时显示0的解决方案在进行sql除法运算时,在DB2的环境下SELECT出来的值是0,这应该如何处理呢?本文将为您介绍DB2中进行sql除法运算结果为小数时显示0问题的两种解决方法,供您参考...
DB2中进行sql除法运算结果为小数时显示0的解决方案
在进行sql除法运算时,在DB2的环境下SELECT出来的值是0,这应该如何处理呢?本文将为您介绍DB2中进行sql除法运算结果为小数时显示0问题的两种解决方法,供您参考。
SELECT field1/field2 FROM TB;
当 field1的数值 & field2的数值时,除法得出的结果是&1的,即0.xxxxxx
这个时候在DB2的环境下SELECT出来的值是0
这个有两个解决方法
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语句修改为:
SELECT CAST(field1 AS DOUBLE)/field2 FROM TB;
就是先把field1转换成DOUBLE类型的,这样计算出来的就会得出小数点了,会显示出0.xxxxxx
接下来,需要对得出的小数点位数进行约束,那就用四舍五入吧,
SELECT ROUND(CAST(field1 AS DOUBLE)/field2, 2) FROM TB;
这个意思就是说四舍五入,保留两位小数点
但是如果field1或者field2有一个字段为NULL的话,那么结果为NULL,这个时候根据逻辑需要进行如下的一个操作,
如果数据列的值为NULL,将其设置为0,那么sql就要这么写
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进行非空判断。被除数为0的除法_图文_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
评价文档:
被除数为0的除法
上传于||文档简介
&&青​岛​版​五​四​制​二​年​级​上​册
大小:3.62MB
登录百度文库,专享文档复制特权,财富值每天免费拿!
你可能喜欢select sum(case d.task_state when 0 then 1 else 0 end)/sum(1),
sum(case d.task_state when 0 then 1 else 0 end),
from week_task_result d
这么写输出的结果是:0 23 24其中第一列为0,而不是23除以24得到的值,为什么?------解决方案--------------------SQL code
select sum(case d.task_state when 0 then 1 else 0 end)* 1.0/sum(1),
sum(case d.task_state when 0 then 1 else 0 end),
from week_task_result d
------解决方案--------------------SQL code
select sum(case d.task_state when 0 then 1 else 0 end)*1.0/sum(1),
sum(case d.task_state when 0 then 1 else 0 end),
from week_task_result d
------解决方案--------------------精度问题
------解决方案--------------------整数和整数乘除,结果为整数。。而23/24=0.958333,所以取整成了0。
12345678910
12345678910
12345678910 上一篇:下一篇:文章评论相关解决方案 12345678910 Copyright & &&版权所有1098人阅读
在进行sql除法运算时,在DB2的环境下SELECT出来的值是0,这应该如何处理呢?本文将为您介绍DB2中进行sql除法运算结果为小数时显示0问题的两种解决方法,供您参考。
SELECT field1/field2 FROM TB;
当 field1的数值 & field2的数值时,除法得出的结果是&1的,即0.xxxxxx
这个时候在DB2的环境下SELECT出来的值是0
这个有两个解决方法
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进行非空判断。
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:135005次
积分:1871
积分:1871
排名:第15284名
原创:48篇
转载:22篇
评论:31条
(2)(1)(3)(1)(1)(1)(5)(2)(1)(2)(2)(5)(6)(3)(1)(2)(11)(6)(9)(2)(1)(3)

我要回帖

更多关于 sql 除法保留小数 的文章

 

随机推荐