四舍五入保留两位小数,不足补0(SQL&JAVA&JS)

oracle写法


select cast(round(3.23457, 2) as decimal(20, 2)) t1,
       cast(round(3.2, 2) as decimal(20, 2)) t2,
       cast(round(3, 2) as decimal(20, 2)) t3
  from dual

在这里插入图片描述

java写法

//保留2位小数
double score = new BigDecimal(score).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
				
//不足两位则补0
DecimalFormat decimalFormat = new DecimalFormat("0.00#");
String scoreStr = decimalFormat.format(score);

Js写法

推荐方法一,方法二适用一些特殊场景
-方法一(推荐,但可能个别场景使用不了)

var num2=3.1
var t1=parseFloat(num2.toFixed(2))
var t2=parseFloat(num2).toFixed(2)//保留两位小数,不足补0
console.log(t1)
console.log(t2)

在这里插入图片描述

  • 方式二(用于数据展示时得强制转换)
 if(amountResult!==undefined && amountResult!==null && amountResult!==""){
          var amountResult= amountResult.toString().indexOf('.')>0?amountResult.length-amountResult.toString().indexOf('.')<3?""+amountResult+'0':amountResult:""+amountResult+'.00';
  }
  • 方式三(两个方式其实思路一样)
   //小数位数不够自动补0,0除外 
    toDecimal2=(x)=> {
      if(!this.isNull(x)){
       if(x===0){
        return 0;
      }else{
        var s = x.toString();
        var rs = s.indexOf('.');
        if (rs < 0) {
         rs = s.length;
       s += '.';
       } 
       while (s.length <= rs + 2) {
         s += '0';
           }
           return s;
      
      }
    }
  }
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值