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

来源:未知 责任编辑:智问网络 发表时间:2013-09-02 11:42 点击:
p>DB2中进行sql除法运算结果为小数时显示0的解决方案

p> 

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

p> 

p>SELECT field1/field2 FROM TB;

p>当 field1的数值 > field2的数值时,除法得出的结果是<1的,即0.xxxxxx

p>这个时候在DB2的环境下SELECT出来的值是0

p>这个有两个解决方法

p> 

p>方法1:

p>DB CFG的一个参数MIN_DEC_DIV_3,这个参数在GET DB CFG FOR DB中并不会列出,但却可以修改。

p>数据库配置参数MIN_DEC_DIV_3会更改涉及小数的十进制算术运算的结果小数位。

p>默认值为No,则小数位计算为 31-p+s-s'。

p>如果设置为Yes,则小数位计算为 MAX(3, 31-p+s-s')。

p>这会导致十进制小数部分始终至少具有3位的小数位。精度始终为31。

p> 

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

p> 

p>将sql语句修改为:

p> 

p>
 SQL1
 SELECT CAST(field1 AS DOUBLE)/field2 FROM TB;

 

p> 

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

p> 

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

p> 

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

 

p> 

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

p> 

p>但是如果field1或者field2有一个字段为NULL的话,那么结果为NULL,这个时候根据逻辑需要进行如下的一个操作,

p>如果数据列的值为NULL,将其设置为0,那么sql就要这么写

p> 

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

 

p> 

p>COALESCE这个函数系统的用法如下:

p>a. 输入参数为字符类型,且允许为空的,可以使用COALESCE(inputParameter,”)把NULL转换成”;

p>b. 输入类型为整型,且允许为空的,可以使用COALESCE(inputParameter,0),把空转换成0;

p> 

p>c. 输入参数为字符类型,且是非空非空格的,可以使用COALESCE(inputParameter,”)把NULL转换成”,然后判断函数返回值是否为”;

p>d. 输入类型为整型,且是非空的,不需要使用COALESCE函数,直接使用IS NULL进行非空判断。

p> 

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • db2管理工具小结
    • DB2数据库的导出与导入(Windows客户端)
    • db2 CLP中如何换行
    • DB2查看表结构及所用表语句
    • DB2 · CREATE TABLESPACE
    • 使用DB2对象:创建模式、表和视图
    • DB2数据库逻辑卷的复制
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1