DECIMAL

https://blog.csdn.net/qq_29039705/article/details/80849370
一、简述
在实际的企业级开发中,经常遇到需要存储金额(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


作者:Ansel_TbN1
来源:CSDN
原文:https://blog.csdn.net/qq_29039705/article/details/80849370
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值