JAVA中价格金额的存储类型
在java项目中,我们会遇到价格、金额的数据,这时候我们java中应该用BigDecimal类型,数据库用decimal类型, 长度可以自定义, 如18; 小数点我们项目中用的是2, 保留2位小数. 此外还要注意的就是默认值, 一定写成0.00, 不要用默认的NULL, 否则在进行加减排序等操作时, 会带来转换的麻烦。
以下是一些换算代码
package com.bigdecimal; import java.math.BigDecimal; import java.math.RoundingMode; public class Test { public static void main(String[] args) { BigDecimal num=new BigDecimal("2"); BigDecimal num1=new BigDecimal("0.01"); //加法 System.out.println(num.add(num1)); //减法 System.out.println(num.subtract(num1)); //乘法 System.out.println(num.multiply(num1)); //除法 System.out.println(num.divide(num1, RoundingMode.HALF_UP)); //比较两个数大小 if (num.compareTo(num1)==-1){ System.out.println(num+"小于"+num1); }else if (num.compareTo(num1)==0){ System.out.println(num+"等于"+num1); }else if (num.compareTo(num1)==1){ System.out.println(num+"大于"+num1); } //精度换算 BigDecimal num2=new BigDecimal("4.281"); //删除多余的小数位 System.out.println(num2.setScale(2,BigDecimal.ROUND_DOWN)); //直接进位 System.out.println(num2.setScale(2,BigDecimal.ROUND_UP)); //四舍五入 System.out.println(num2.setScale(2,BigDecimal.ROUND_HALF_UP)); //五舍六入 System.out.println(num2.setScale(2,BigDecimal.ROUND_HALF_DOWN)); } }
结果
2.01
1.99
0.02
200
2大于0.01
4.28
4.29
4.28
4.28
-----------------------有任何问题可以在评论区评论,也可以私信我,我看到的话会进行回复,欢迎大家指教------------------------
(蓝奏云官网有些地址失效了,需要把请求地址lanzous改成lanzoux才可以)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了