decimal
一、简述
在实际的企业级开发中,经常遇到需要存储金额(3888.00元)的字段,这时候就需要用到数据类型decimal。
在mysql数据库中,DECIMAL的使用语法是:DECIMAL(M,D),其中,
M 的范围是1~65,
D 的范围是0~30,
而且D不能大于M。
二、最大值
数据类型为DECIMAL的字段,可以存储的最大值/范围是多少?
例如:DECIMAL(5,2),则该字段可以存储-999.99~999.99,最大值为999.99。
也就是说D表示的是小数部分长度,(M-D)表示的是整数部分长度。
三、存储
DECIMAL类型的数据存储形式是,将每9位十进制数存储为4个字节(官方解释:Values for DECIMAL columns are stored using a binary format that packs nine decimal digits into 4 bytes)。
那有可能设置的位数不是9的倍数,官方还给了如下表格对照:
Leftover Digits | Number of Bytes |
0 | 0 |
1–2 | 1 |
3–4 | 2 |
5–6 | 3 |
7–9 | 4 |
表格什么意思呢,举个例子:
1、字段DECIMAL(18,9),18-9=9,这样整数部分和小数部分都是9,那两边分别占用4个字节;
2、字段DECIMAL(20,6),20-6=14,其中小数部分为6,就对应上表中的3个字节,而整数部分为14,14-9=5,就是4个字节再加上表中的3个字节。
四、参考
https://dev.mysql.com/doc/refman/8.0/en/precision-math-decimal-characteristics.html
Copyright © 2018 Ansel. All rights reserved.
相关阅读
我们在Mysql中存字段的时候,比如,一些与金钱有关的数据。这个时候就会对精确到的要求非常高。那么这个时候,就会发现我们之前所学
BigDecimal中pide方法抛异常:Non-terminating decimal expansion; no exact representable decimal result 在使用 BigDecimal
前阵子做题遇到了大数的精确计算,再次认识了bigdecimal关于Bigdecimal意外的有许多小知识点和坑,这里特此整理一下为方便以后学习,希
关于Java中DecimalFormat()方法的调用 我们可以从各种地方知道DecimalFormat类的使用方法,它的作用是格式化数字。 在此不多赘述,
package cn.itcast_02;import java.math.BigDecimal;/** 构造方法:* public BigDecimal(String val):** 金融相关