SqlServer中decimal,float 和 real 数据类型的区别

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SqlServer中decimal,float 和 real 数据类型的区别相关的知识,希望对你有一定的参考价值。

参考技术A SqlServer中decimal,float 和 real 数据类型的区别如下:
decimal(numeric ) 同义,用于精确存储数值
float 和 real 不能精确存储数值

decimal 数据类型最多可存储 38 个数字,所有数字都能够放到小数点的右边。decimal 数据类型存储了一个准确(精确)的数字表达法;不存储值的近似值。
定义 decimal 的列、变量和参数的两种特性如下:
p 小数点左边和右边数字之和,不包括小数点。如 123.45,则 p=5,s=2。
指定精度或对象能够控制的数字个数。
s
指定可放到小数点右边的小数位数或数字个数。
p 和 s 必须遵守以下规则:0 <= s <= p <= 38。
numeric 和 decimal 数据类型的默认最大精度值是 38。在 Transact-SQL 中,numeric 与 decimal 数据类型在功能上等效。
当数据值一定要按照指定精确存储时,可以用带有小数的 decimal 数据类型来存储数字。
float 和 real 数据
float 和 real 数据类型被称为近似的数据类型。在近似数字数据类型方面,float 和 real 数据的使用遵循 IEEE 754 标准。
近似数字数据类型并不存储为多数数字指定的精确值,它们只储存这些值的最近似值。在很多应用程序中,指定值与存储值之间的微小差异并不明显。但有时这些差异也值得引起注意。由于 float 和 real 数据类型的这种近似性,当要求精确的数字状态时,比如在财务应用程序中,在那些需要舍入的操作中,或在等值核对的操作中,就不使用这些数据类型。这时就要用 integer、decimal、money 或 smallmone 数据类型。
在 WHERE 子句搜索条件中(特别是 = 和 <> 运算符),应避免使用 float 或 real 列。最好限制使用 float 和 real 列做 > 或 < 的比较。
IEEE 754 规格提供了四种舍入模式:舍入到最接近的值、上舍入、下舍入和舍入到零。Microsoft® SQL Server™ 使用上舍入。所有的数值必须精确到确定的精度,但会产生细小的浮点值变化。因为浮点数字的二进制表示法可以采用很多合法舍入规则中的任意一条,因此我们不可能可靠地量化一个浮点值。

MySQL中Decimal类型和Float Double的区别

参考技术A 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
test(f
FLOAT(5,2)
DEFAULT
NULL,d
DOUBLE(5,2)
DEFAULT
NULL,de
DECIMAL(5,2)
DEFAULT
NULL);
2、DESC
test;
3、INSERT
INTO
test(f,d,de)
VALUES(1.23,1.23,1.23);
数据插入都正确
4、INSERT
INTO
test(f,d,de)
VALUES(1.234,1.234,1.23);
数据插入都正确,但是f和d由于标度的限制,舍去了最后一位。
5、INSERT
INTO
test(f,d,de)
VALUES(1.234,1.234,1.234);
数据也插入成功,但是有一个警告提示:
1
queries
executed,
1
success,
0
errors,
1
warnings
Note
Code
:
1265
Data
truncated
for
column
'de'
at
row
1
6、将id1,id2,id3的精度和标度都去掉
ALTER
TABLE
test
MODIFY
f
FLOAT;
ALTER
TABLE
test
MODIFY
d
DOUBLE;
ALTER
TABLE
test
MODIFY
de
DECIMAL;
DELETE
FROM
test;
DESC
test;
7、INSERT
INTO
test(f,d,de)
VALUES(1.234,1.234,1.234);
1
queries
executed,
1
success,
0
errors,
1
warnings
Note
Code
:
1265
Data
truncated
for
column
'de'
at
row
1
f和d的数据正确插入,而de被截断。
浮点数如果不写精度和标度,则会按照实际显示,如果有精度和标度,则会将数据四舍五入后插入,系统不报错,定点数如果不设置精度和标度,刚按照默认的(10,0)进行操作,如果数据超过了精度和标度值,则会警告!
同时,对数据求SUM()时会出现不同的结果,float和double求SUM都会出现很多小数点,而decimal求SUM得到的是精准数值:
8、INSERT
INTO
test(f,d,de)
VALUES(1.234,0.01,1.23);
数据都插入成功
9、SELECT
SUM(f),SUM(d),SUM(de)
FROM
test;
理论上SUM(f)=3.698,SUM(d)=2.474,SUM(de)=3.46,但f,d都出现后面很长的一串浮点小数点。

以上是关于SqlServer中decimal,float 和 real 数据类型的区别的主要内容,如果未能解决你的问题,请参考以下文章

SqlServer中decimal(numeric )float 和 real 数据类型的区别[转]

SQL Server 小数类型(float 和 decimal)小数相除求占比为1的方法

使用Float或Decimal作为会计应用程序的美元金额?

sql server 货币 字段 类型 一般用啥类型?

sql server 小数字段设为哪种类型?

SQLServer