一、简述
在实际的企业级开发中,经常遇到需要存储金额(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的倍数,官方还给了如下表格对照:
表格什么意思呢,举个例子:
1、字段DECIMAL(18,9),18-9=9,这样整数部分和小数部分都是9,那两边分别占用4个字节;
2、字段DECIMAL(20,6),20-6=14,其中小数部分为6,就对应上表中的3个字节,而整数部分为14,14-9=5,就是4个字节再加上表中的3个字节。
四、参考
characteristics.htmlhttps://dev.mysql.com/doc/refman/8.0/en/precision-math-decimal-characteristics.html