金钱在类型and工具类
一、金钱类型
1、java中类型
1.1、BigDecimal和BigInteger
java.math.BigDecimal
不变的,任意精度的带符号的十进制数字。
public class BigDecimal extends Number implements Comparable
BigDecimal的就是防止金钱数据失真,在实际使用场景中,金钱是不允许有失真或者四舍五入这样的出现的,金钱必须精确,
对应BigDecimal这个东西是一个对象,在操作其的时候需要使用对应的方法操作
- add(BigDecimal)
BigDecimal对象中的值相加,返回BigDecimal对象 - subtract(BigDecimal)
BigDecimal对象中的值相减,返回BigDecimal对象 - multiply(BigDecimal)
BigDecimal对象中的值相乘,返回BigDecimal对象 - divide(BigDecimal)
BigDecimal对象中的值相除,返回BigDecimal对象 - toString()
将BigDecimal对象中的值转换成字符串 - doubleValue()
将BigDecimal对象中的值转换成双精度数 - floatValue()
将BigDecimal对象中的值转换成单精度数 - longValue()
将BigDecimal对象中的值转换成长整数 - intValue()
将BigDecimal对象中的值转换成整数
public class BigDecimalUtil { /** * 常用的常量—1000 */ public final static BigDecimal DECIMAL_1000 = new BigDecimal("1000"); /** * 常用的常量—100 */ public final static BigDecimal DECIMAL_100 = new BigDecimal("100"); /** * 常用的常量0 */ public final static BigDecimal DECIMAL_0 = new BigDecimal("0"); /** * 如果==null or 0返回true * @param v * @return */ public static Boolean isNullOrZero(BigDecimal v){ return v == null || v.compareTo(BigDecimal.ZERO) == 0; } /** * 如果==null返回0 * @param v * @return */ public static BigDecimal isNullReturnZero(BigDecimal v){ return v == null ? BigDecimal.ZERO : v; } /** * 如果==null返回0 * @param v 请确定是个数字 * @return */ public static BigDecimal isNullReturnZero(Object v){ return v == null ? BigDecimal.ZERO : toBigDecimal(v); } /** * 如果==null返回"" * @param v * @return */ public static String isNullReturnBlank(BigDecimal v){ return v == null ? "" : v.toString(); } /** * BigDecimal保留小数 * 默认进一法 * @param val 值 * @return */ public static BigDecimal setScaleUp(BigDecimal val){ return isNullOrZero(val) ? BigDecimal.ZERO.setScale(2, BigDecimal.ROUND_UP) : val.setScale(2, BigDecimal.ROUND_UP); } /** * BigDecimal保留小数 * @param val 值 * @param newScale 保留几位小数 * @return */ public static BigDecimal setScale(BigDecimal val, int newScale){ return isNullOrZero(val) ? BigDecimal.ZERO.setScale(newScale, BigDecimal.ROUND_HALF_UP) : val.setScale(newScale, BigDecimal.ROUND_HALF_UP); } /** * BigDecimal保留小数 * @param val 值 * @param newScale 保留几位小数 * @return */ public static BigDecimal setScale(Object val, int newScale){ BigDecimal decimal = toBigDecimal(val); return isNullOrZero(decimal) ? BigDecimal.ZERO.setScale(newScale, BigDecimal.ROUND_HALF_UP) : decimal.setScale(newScale, BigDecimal.ROUND_HALF_UP); } /** * BigDecimal保留小数 * @param val 值 * @param newScale 保留几位小数 * @param roundingMode 保留小数方法 * @return */ public static BigDecimal setScale(BigDecimal val, int newScale, int roundingMode){ return isNullOrZero(val) ? BigDecimal.ZERO.setScale(newScale, roundingMode) : val.setScale(newScale, roundingMode); } /** * BigDecimal保留小数 * @param val 值 * @param newScale 保留几位小数 * @param roundingMode 保留小数方法 * @return */ public static BigDecimal setScale(String val, int newScale, int roundingMode){ BigDecimal bigDecimal = toBigDecimal(val); return isNullOrZero(bigDecimal) ? BigDecimal.ZERO.setScale(newScale, roundingMode) : bigDecimal.setScale(newScale, roundingMode); } /** * BigDecimal保留小数 * @param val 值 * @param newScale 保留几位小数 * @param roundingMode 保留小数方法 * @return */ public static BigDecimal setScale(Object val, int newScale, int roundingMode){ BigDecimal bigDecimal = toBigDecimal(val); return isNullOrZero(bigDecimal) ? BigDecimal.ZERO.setScale(newScale, roundingMode) : bigDecimal.setScale(newScale, roundingMode); } /** * BigDecimal除法 * 保留四位小数 * @param v1 除数 * @param v2 被除数 * @return */ public static BigDecimal divide(BigDecimal v1, BigDecimal v2){ if (v1 == null || v1.compareTo(BigDecimal.ZERO) ==0 || v2 == null || v2.compareTo(BigDecimal.ZERO) == 0){ return BigDecimal.ZERO; } return v1.divide(v2, 4, BigDecimal.ROUND_HALF_UP); } /** * * BigDecimal除法 * 指定保留scale位小数 * @param v1 除数 * @param v2 被除数 * @param scale * @return */ public static BigDecimal divide(BigDecimal v1, BigDecimal v2, @NotNull Integer scale){ if (v1 == null || v1.compareTo(BigDecimal.ZERO) ==0 || v2 == null || v2.compareTo(BigDecimal.ZERO) == 0){ return BigDecimal.ZERO; } return v1.divide(v2, scale, RoundingMode.HALF_UP); } /** * BigDecimal乘法 * 保留四位小数 默认四舍五入 * @param v1 * @param v2 * @return */ public static BigDecimal multiply(BigDecimal v1, BigDecimal v2){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.multiply(v2).setScale(4, BigDecimal.ROUND_HALF_UP); } /** * BigDecimal乘法 * 保留四位小数 默认四舍五入 * @param v1 除数 * @param v2 被除数 * @return */ public static BigDecimal multiply(BigDecimal v1, BigDecimal v2, int newScale){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.multiply(v2).setScale(newScale, BigDecimal.ROUND_HALF_UP); } /** * * BigDecimal乘法 * @param v1 * @param v2 * @param newScale 保留几位小数 * @param roundingMode 保留小数的方法 * @return */ public static BigDecimal multiply(BigDecimal v1, BigDecimal v2, int newScale, int roundingMode){ if (v2.compareTo(BigDecimal.ZERO) == 0 || v1.compareTo(BigDecimal.ZERO) == 0){ return BigDecimal.ZERO.setScale(newScale); } return v1.multiply(v2).setScale(newScale, roundingMode); } /** * BigDecimal加法 * 保留四位小数 默认四舍五入 * @param v1 除数 * @param v2 被除数 * @return */ public static BigDecimal add(BigDecimal v1, BigDecimal v2){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.add(v2).setScale(4, BigDecimal.ROUND_HALF_UP); } /** * * BigDecimal加法 * @param v1 * @param v2 * @param newScale 保留几位小数 * @param roundingMode 保留小数的方法 * @return */ public static BigDecimal add(BigDecimal v1, BigDecimal v2, int newScale, int roundingMode){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.add(v2).setScale(newScale, roundingMode); } /** * BigDecimal减法 * 保留四位小数 默认四舍五入 * @param v1 除数 * @param v2 被除数 * @return */ public static BigDecimal subtract(BigDecimal v1, BigDecimal v2){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.subtract(v2).setScale(4, BigDecimal.ROUND_HALF_UP); } /** * BigDecimal减法 * 保留四位小数 默认四舍五入 * @param v1 减数 * @param v2 被减数 * @return */ public static BigDecimal subtract(BigDecimal v1, BigDecimal... v2){ v1 = isNullReturnZero(v1); for (BigDecimal decimal : v2) { v1 = subtract(v1, isNullReturnZero(decimal), 4, BigDecimal.ROUND_HALF_UP); } return v1; } /** * * BigDecimal减法 * @param v1 * @param v2 * @param newScale 保留几位小数 * @param roundingMode 保留小数的方法 * @return */ public static BigDecimal subtract(BigDecimal v1, BigDecimal v2, int newScale, int roundingMode){ v1 = isNullReturnZero(v1); v2 = isNullReturnZero(v2); return v1.subtract(v2).setScale(newScale, roundingMode); } /** * Object转BigDecimal类型 * * @param value 传入Object值 * @return 转成的BigDecimal类型数据 */ public static BigDecimal toBigDecimal(Object value) { if (value == null || "".equals(value)){ return null; } if (value instanceof BigDecimal) { return (BigDecimal) value; } else if (value instanceof String) { return new BigDecimal(String.valueOf(value)); } else if (value instanceof BigInteger) { return new BigDecimal(String.valueOf(value)); } else if (value instanceof Number) { return new BigDecimal(String.valueOf(value)); } else { throw new ClassCastException("Can Not make [" + value + "] into a BigDecimal."); } } public static void main(String[] args) { BigDecimal bigDecimalOne = new BigDecimal(10.0); BigDecimal bigDecimalTwo = new BigDecimal(5.0); System.out.println(bigDecimalOne.divide(bigDecimalTwo,4, RoundingMode.HALF_UP)); } }
2、MYSQL中
2.1、Decimal
DECIMAL从MySQL 5.1引入,列的声明语法是DECIMAL(M,D)。在MySQL 5.1中,参量的取值范围如下:
- M是数字的最大数(精度)。其范围为1~65(在较旧的MySQL版本中,允许的范围是1~254),M 的默认 值是10。
- D是小数点右侧数字的数目(标度)。其范围是0~30,但不得超过M。
说明:float占4个字节,double占8个字节,decimail(M,D)占M+2个字节。
如DECIMAL(5,2) 的最大值为9 9 9 9 . 9 9,因为有7 个字节可用。
参考文章
个人笔记,不同意见,望有交流
直接可以点击跳转连接
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)