• Oracle number类型查询精度丢失的解决方法


    Oracle number类型查询时,有时候会遇到精度丢失的问题,下面为您介绍了一个解决Oracle number类型查询精度丢失的方法,供您参考。

    一、Oracle number类型查询需求中要求查到一个字段的值然后保持小数点后2位//如果采用如下方法从ResultSet得到一个数字,而这个数字大于40000,则得到的数据将不准确

    floatzcxxhj+=rss.getFloat(3);

    //而如果采用double就没有问题

    doublezcxxhj+=rss.getDouble(3);

    //四舍五入小数点后2位

    list.add(newBigDecimal(zcxxhj).setScale(2,BigDecimal.ROUND_HALF_UP));

    二,如果Oracle number类型查询要求从数据库查出来的数保持到小数点后2位,然后直接再前台展示那么我们可以采用如下查询方法:例子:

    selectfpdm, fphm, fkdw, to_char(kprq,'yyyy-mm-dd'), to_char(xxhj,'FM9999999999990.00'), Decode(fpzt,'1','正票','2','红票','3','废票') fromwskp_fpkj_zbxx_111000861071 where11=1 andnsrsbh='110999999999999'

    其中的xxhj是number类型,我们可以将其通过 to_char(xxhj, 'FM990.00'),保持小树点后最少2位,小数点前面做多3位,最少1位;又如 to_char(xxhj, 'FM9990.0099'),就是保持小数点后最少2位,最多4位,小数点前面做多4位,最少1位 三、如果要求查到的数相加后保持小树点后2位

    doubled=rss.getDouble(3)+rss.getDouble(4); BigDecimalbigDecimal=newBigDecimal(d).setScale(2,BigDecimal.ROUND_HALF_UP); beanData.setXxhj(bigDecimal.toString());

  • 相关阅读:
    MySQL错误 1030-Got error 28 from storage engine
    电脑开机无反应 不显示BIOS 硬件没问题
    python错误 import: unable to open X server
    Python 错误 invalid command 'bdist_wheel' & outside environment /usr
    Cento 7安装 Failed to execute /init
    笔记《鸟哥的Linux私房菜》5 首次登入与在线求助 man
    Scrapy XPath语法
    Linux 用户操作
    Mysql 表修改
    Ubuntu 配置 Python环境 IPython
  • 原文地址:https://www.cnblogs.com/ihuning/p/6193663.html
Copyright © 2020-2023  润新知