广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中float double和decimal类型有何区别
  • 536
分享到

MySQL中float double和decimal类型有何区别

2024-04-02 19:04:59 536人浏览 泡泡鱼
摘要

下文主要给大家带来Mysql中float double和decimal类型有何区别,希望这些内容能够带给大家实际用处,这也是我编辑mysql中float double和decimal类型有何区别这篇文章的主

下文主要给大家带来Mysql中float double和decimal类型有何区别,希望这些内容能够带给大家实际用处,这也是我编辑mysql中float double和decimal类型有何区别这篇文章的主要目的。好了,废话不多说,大家直接看下文吧。

float数值类型用于表示单精度浮点数值,而double数值类型用于表示双精度浮点数值,

float和double都是浮点型,而decimal是定点型;


Mysql 浮点型和定点型可以用类型名称后加(M,D)来表示,

M表示该值的总共长度,D表示小数点后面的长度,

M和D又称为精度和标度,如float(7,4)的 可显示为-999.9999,

MySQL保存值时进行四舍五入,如果插入999.00009,则结果为999.0001。


☆FLOAT和DOUBLE在不指 定精度时,默认会按照实际的精度来显示,而DECIMAL在不指定精度时,默认整数为10,小数为0。


测试1:

CREATE TABLE test1 (
f FLOAT(5,2) DEFAULT NULL,
d DOUBLE(5,2) DEFAULT NULL,
de DECIMAL(5,2) DEFAULT NULL
);
INSERT INTO test1(f,d,de) VALUES(1.23,1.23,1.23);

数据插入正确:MySQL中float double和decimal类型有何区别

2.

INSERT INTO test1(f,d,de) VALUES(1.234,1.234,1.23);

数据插入都正确,但是f和d由于标度的限制,舍去了最后一位。

MySQL中float double和decimal类型有何区别

3.

INSERT INTO test1(f,d,de) VALUES(1.234,1.234,1.234);

插入成功,但是有警告

MySQL中float double和decimal类型有何区别

MySQL中float double和decimal类型有何区别

4.把f,d,de的精度和标度去掉。

INSERT INTO test1(f,d,de) VALUES(1.234,1.234,1.234);

插入正确【f和d的数据正确插入,而de被截断】,同时也会有3一样的提示!

浮点数如果不写精度和标度,则会按照实际显示,如果有精度和标度,则会将数据四舍五入后插入,系统不报错,定点数如果不设置精度和标度,刚按照默认的(10,0)进行操作,如果数据超过了精度和标度值,则会警告!

MySQL中float double和decimal类型有何区别


5. 数据求SUM()时会出现不同的结果,float和double求SUM都会出现很多小数点,而decimal求SUM得到的是精准数值:

SELECT SUM(f),SUM(d),SUM(de) FROM test1;

MySQL中float double和decimal类型有何区别

MySQL中float double和decimal类型有何区别

理论上:f,d后面不应该出现很长的一串浮点小数点的。


6.loat列类型默认长度查不到结果,必须指定精度

SELECT * FROM test1  WHERE f = 1.234;

查不到任何一列。

7.

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

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

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

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

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

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

decimal dd=345.545454879.....//可以支持28位,对最后一位四舍五入。因为高精度,28位的有效位数,这才是财务计算中使用的最主要原因。

所有浮点数计算都有精度损失问题,而decimal同样是浮点数[定点数],所以同样有精度损失!

下面的输出结果与不进行相加操作相同,并且没有异常。同样造成了精度损失,不过dd的有效位数超过了28位

MySQL中float double和decimal类型有何区别

综上,如果你做财务方面,那么用decimal吧,如果你计算的数值是人类所用的,那么也用decimal吧。double感觉就是个鸡肋,还真想不出什么用到的地方。【网上观点,只供参考】

对于以上关于MySQL中float double和decimal类型有何区别,大家是不是觉得非常有帮助。如果需要了解更多内容,请继续关注我们的数据库,相信你会喜欢上这些内容的。

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中float double和decimal类型有何区别

本文链接: https://www.lsjlt.com/news/35562.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中float double和decimal类型有何区别
    下文主要给大家带来MySQL中float double和decimal类型有何区别,希望这些内容能够带给大家实际用处,这也是我编辑MySQL中float double和decimal类型有何区别这篇文章的主...
    99+
    2022-10-18
  • MySQL中float、double、decimal三个浮点类型有什么区别
    这篇文章给大家分享的是有关MySQL中float、double、decimal三个浮点类型有什么区别的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。下表中规划了每个浮点类型的存储大...
    99+
    2022-10-18
  • 浅谈MySQL中float、double、decimal三个浮点类型的区别与总结
    下表中规划了每个浮点类型的存储大小和范围: 类型 大小 范围(有符号) 范围(无符号) 用途 ...
    99+
    2022-05-11
    MySQL float double decimal
  • SQL中的real、float、decimal、numeric数据类型区别
    概述: 浮点数据类型包括real型、float型、decimal型和numeric型。浮点数据类型用于存储十进制小数。 在SQL Server 中浮点数值的数据采用上舍入(Round up)的方式进行存储,所谓上舍入也就是,要舍...
    99+
    2021-05-09
    SQL中的real float decimal numeric数据类型区别
  • php中float和double的区别有哪些
    这篇“php中float和double的区别有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“php中float和doub...
    99+
    2023-06-29
  • 关于MYSQL中FLOAT和DOUBLE类型的存储
    关于MYSQL中FLOAT和DOUBLE类型的存储 其实在单精度和双精度浮点类型存储中其存储方式和C/C++一致准守IEEE标准他们都是浮点型的,所谓的浮点型,是小数点的位置可变,其能够表示的范围比定点...
    99+
    2022-10-18
  • MySQL中float和decimal类型的作用是什么
    本篇文章给大家分享的是有关MySQL中float和decimal类型的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 float,d...
    99+
    2022-10-18
  • mysql中float 和double类型的作用是什么
    mysql中float 和double类型的作用是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。float double类...
    99+
    2022-10-18
  • MySQL中varchar和char类型有什么区别
    本篇内容介绍了“MySQL中varchar和char类型有什么区别”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!VARCHAR类型VARCH...
    99+
    2023-06-25
  • MySQL中varchar和char类型的区别
    目录前述VARCHAR类型VARCHAR适用情况CHAR类型测试VARCHAR(5)与VARCHAR(200)的区别总结前述 VARCHAR和CHAR是两种最主要的字...
    99+
    2022-11-12
  • MySQL 中的 BLOB 和 TEXT 数据类型有什么区别?
    BLOB代表Binary Large Objects,顾名思义,它可以用于存储二进制数据,而TEXT用于存储大量字符串。 BLOB可以用来存储二进制数据,这意味着我们还可以存储图片、视频、声音和程序。 例如,下面的图像可以存储为 BLOB,...
    99+
    2023-10-22
  • MySQL DATETIME 和 TIMESTAMP 数据类型有什么区别?
    两种数据类型都以“YYYY-MM-DD HH:MM:SS”格式存储数据,并包含日期和时间。尽管有这些相似之处,但它们还是有以下区别 -范围 - 日期时间数据类型支持 1000 之间的日期和时间-01-01 00:00:00 和 9999-1...
    99+
    2023-10-22
  • javascript中原始类型和引用类型有什么区别
    小编给大家分享一下javascript中原始类型和引用类型有什么区别,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1、区别(1)原始类型存储的是值,引用类型存储的...
    99+
    2023-06-15
  • Java中引用类型和原始类型有什么区别
    本篇文章给大家分享的是有关Java中引用类型和原始类型有什么区别,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Java 提供两种不同的类型:引用类型和原始类型(或内置类型)。另...
    99+
    2023-06-17
  • MySQL字符串类型中VARCHAR和CHAR的区别
    前述VARCHAR和CHAR是两种最主要的字符串类型。不幸的是,很难精确地解释这些值是怎么存储在磁盘和内存中的,因为这跟存储引擎的具体实现有关。下面的描述假设使用的存储引擎是InnoDB和/或者MyISAM...
    99+
    2022-10-18
  • python中可变数据类型和不可变数据类型有什么区别
    这篇文章将为大家详细讲解有关python中可变数据类型和不可变数据类型有什么区别,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、区别说明可变数据类型是当该数据类型对应变量的值发生变化时,对...
    99+
    2023-06-15
  • MySQL 中 DATETIME 和 TIMESTAMP 时间类型的区别及使用场景
    MySQL的日期类型简介 在 MySQL 中有两种存储时间的数据类型 DATETIME 和 TIMESTAMP,它们在数据库实际应用中,各有各的优势和劣势。 一. DATETIME 和 TIMESTAMP 的相同点 两个数据类型存储时...
    99+
    2023-09-01
    mysql sql 数据库
  • Javascript中类式继承和原型式继承有什么区别
    这篇文章主要介绍了Javascript中类式继承和原型式继承有什么区别,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。在所有面向对象的编程中,...
    99+
    2022-10-19
  • 数据类型和数组在PHP和Apache服务器中有什么区别?
    在PHP和Apache服务器中,数据类型和数组是非常重要的概念,它们在程序开发中扮演着至关重要的角色。虽然它们都是用来存储数据的,但是它们之间存在着一些区别。本文将深入探讨数据类型和数组在PHP和Apache服务器中的区别。 一、数据类型在...
    99+
    2023-09-15
    apache 数组 数据类型
  • 数据类型在Python和Shell中有什么区别?如何进行打包操作?
    在Python和Shell两种编程语言中,数据类型是一个非常重要的概念。不同的数据类型具有不同的性质和用途,因此在编写程序时需要对其进行正确的使用和操作。本文将介绍Python和Shell中常见的数据类型以及它们之间的区别,并介绍如何对数...
    99+
    2023-10-13
    数据类型 打包 shell
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作