一、简述
在实际的企业级开发中,经常遇到需要存储金额(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个字节。
四、参考
Copyright © 2018 Ansel. All rights reserved.