mysql数据库decimal类型与decimal长度用法详解

 更新时间:2024年01月03日 09:04:07   作者:鲲志说  
在MySQL中decimal是一种用于存储精确数字的数据类型,下面这篇文章主要给大家介绍了关于mysql数据库decimal类型与decimal长度用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

项目涉及到金钱的存储,数据库对应字段类型建议使用decimal,这是今天学到的。

下面我们来一起学习一下

1.三者的区别介绍

float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位)

double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)

decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)

2.按存储的范围进行排序

float(real)
double
decimal(numeric)

3.decimal的详细介绍

decimal(a,b)

参数说明:

a指定指定小数点左边和右边可以存储的十进制数字的最大个数,最大精度38。 b指定小数点右边可以存储的十进制数字的最大个数。小数位数必须是从
0 到 a之间的值。默认小数位数是 0。

备注

DECIMAL数据类型用于要求非常高的精确度的计算中,这些类型允许指定数值的精确度和计数方法作为选择参数。精确度在这里是指为这个值保存的有效数字的总个数,而计数方法表示小数点后数字的个数。例如,语句DECIMAL
(5,2)规定了存储的值将不会超过5位数字,开且小数点后面有2位数字。

实例

float f = 345.98756f;--结果显示为345.9876,只显示7个有效位,对最后一位数四舍五入。

double d=345.975423578631442d;--结果显示为345.975423578631,只显示15个有效位,对最后一位四舍五入。

--注:float和double的相乘操作,数字溢出不会报错,会有精度的损失。

decimal dd=345.545454879.....--可以支持28位,对最后一位四舍五入。

--:当对decimal类型进行操作时,数值会因溢出而报错。

总结

数值存储范围越小的精度越高,存储数值范围越大,精度就越不准确,如果存储正常金额的情况下,使用money,好处在于可以存储不指定的小数点位数的数值,比较真实。如果对于既要求精度,又固定小数点位数的数值存储,采用decimal(numeric),优点在于可以自定义小数点位数,精度高。如特殊情况,如数值范围巨大只能用float(real)类型了,此类型一般不提倡使用。

到此这篇关于mysql数据库decimal类型与decimal长度用法的文章就介绍到这了,更多相关mysql decimal与decimal长度用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL中的字符替换示例详解

    MySQL中的字符替换示例详解

    本文介绍了 MySQL 中的两种字符替换函数:REPLACE 和 REGEXP_REPLACE,通过这两个函数的使用,我们可以方便地进行字符替换操作,提高数据处理的效率和准确性,感兴趣的朋友跟随小编一起看看吧
    2023-06-06
  • 详细分析mysql视图的原理及使用方法

    详细分析mysql视图的原理及使用方法

    这篇文章主要介绍了mysql视图的相关资料,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下
    2020-08-08
  • Windows平台配置5.7版本+MySQL数据库服务

    Windows平台配置5.7版本+MySQL数据库服务

    这篇文章主要介绍了Windows平台配置5.7版本+MySQL数据库服务的方法,包括初始化root用户密码password的过程以及两个常见问题的解决方法,需要的朋友参考下吧
    2017-06-06
  • MySQL修改root密码的3种实用方法

    MySQL修改root密码的3种实用方法

    最近在看项目,搭建本地环境时候,忘记mysql的密码,怎么修改密码,网上找了半天,终于配合着几个帖子搞定了,下面这篇文章主要给大家介绍了关于MySQL修改root密码的3种实用方法,需要的朋友可以参考下
    2023-11-11
  • mysql常用sql与命令之从入门到删库跑路

    mysql常用sql与命令之从入门到删库跑路

    这篇文章主要介绍了mysql sql命令之从入门到删库跑路的相关命令与操作
    2021-03-03
  • MySQL中延迟复制的实现

    MySQL中延迟复制的实现

    MySQL延迟复制允许副本服务器滞后源服务器指定时间,用于数据保护、历史检查等,延迟复制通过设置MASTER_DELAY选项实现,下面就来介绍 一下,感兴趣的可以了解一下
    2025-02-02
  • centOS安装mysql5.7详细教程

    centOS安装mysql5.7详细教程

    这篇文章主要为大家介绍了centOS安装mysql5.7详细教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • 一文带你理解MySQL TCL 事务控制

    一文带你理解MySQL TCL 事务控制

    本文主要介绍了MySQL TCL事务控制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-11-11
  • MySQL union 语法代码示例分析

    MySQL union 语法代码示例分析

    主要介绍的是MySQLunion 语法代码演示,我前两天在相关网站看见MySQLunion 语法代码演示的资料,觉得挺好,就拿出来供大家分享。希望在你今后的学习中会对你有所帮助。
    2010-06-06
  • Linux/Mac MySQL忘记密码命令行修改密码的方法

    Linux/Mac MySQL忘记密码命令行修改密码的方法

    这篇文章主要介绍了Linux/Mac MySQL忘记密码命令行修改密码的方法,需要的朋友可以参考下
    2017-05-05

最新评论