zoukankan      html  css  js  c++  java
  • 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());

  • 相关阅读:
    第四阶段学习总结
    第三阶段学习总结
    第二阶段学习总结
    第一阶段内容的学习总结
    第四单元及OO课程总结
    关于工具的碎碎念
    第三单元博客总结
    第二单元博客总结
    第一单元作业总结
    实验五 单元测试
  • 原文地址:https://www.cnblogs.com/ihuning/p/6193663.html
Copyright © 2011-2022 走看看