共计 1309 个字符,预计需要花费 4 分钟才能阅读完成。
自动写代码机器人,免费开通
MySQL 中 decimal 如何使用,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面丸趣 TV 小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
decimal 介绍
在设计数据库时, 如果你要存储价格之类带小数点的数据, 们一般比如价格,我会用 decimal 类型,不会考虑 float,double, 因为他们容易产生误差,numeric 和 decimal 同义,numeric 将自动转成 decimal。
ps: 至于为什么会产生误差, 请看我的另外一篇文章: php 中浮点数计算问题。
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) 的最大值为 9999.99,因为有 7 个字节可用。
首先,对于精度比较高的东西,比如 money,我会用 decimal 类型,不会考虑 float,double, 因为他们容易产生误差,numeric 和 decimal 同义,numeric 将自动转成 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 个字节可用。
M 与 D 对 DECIMAL(M, D) 取值范围的影响。
类型说明取值范围 (MySQL 3.23) 取值范围(MySQL = 3.23)
MySQL 3.23 MySQL =3.23
DECIMAL(4, 1) -9.9 到 99.9 -999.9 到 9999.9
DECIMAL(5,1) -99.9 到 999.9 -9999.9 到 99999.9
DECIMAL(6,1) -999.9 到 9999.9 -99999.9 到 999999.9
DECIMAL(6,2) -99.99 到 999.99 -9999.99 到 99999.99
DECIMAL(6,3) -9.999 到 99.999 -999.999 到 9999.999
# 在 MySQL 3.23 及以后的版本中,DECIMAL(M, D) 的取值范围等于早期版本中的 DECIMAL(M + 2, D) 的取值范围。
结论
1. 当数值在其取值范围之内,小数位多了,则小数会四舍五入。
2. 若数值在其取值范围之外,则用最大 (小) 值对其填充。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注丸趣 TV 行业资讯频道,感谢您对丸趣 TV 的支持。
向 AI 问一下细节