MySQL中decimal如何使用

66次阅读
没有评论

共计 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 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计1309字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)