MySQL中的定点数类型只有DECIMAL一种类型。
数据类型 | 字节数 | 含义 |
---|---|---|
DECIMAL(M,D),DEC,NUMERIC | M + 2字节 | 有效范围由M和D决定 |
使用DECIMAL(M,D)的方式表示高精度小数。其中,M被称为精度,D被称为标度。O<=M<=65,0<=D<=30,D<M。例如,定义DECIMAL (5,2)的类型,表示该列取值范围是-999.99~999.99。
- DECIMAL(M,D)的最大取值范围与DOUBLE类型一样,但是有效的数据范围是由M和D决定的。DECIMAL的存储空间并不是固定的,由精度值M决定,总共占用的存储空间为M+2个字节。也就是说,在一些对精度要求不高的场景下,比起占用同样字节长度的定点数,浮点数表达的数值范围可以更大一些。
- 定点数在MySQL内部是以字符串的形式进行存储,这就决定了它一定是精准的。
- 当DECIMAL类型不指定精度和标度时,其默认为DECIMAL(10,0)。当数据的精度超出了定点数类型的精度范围时,则MySQL同样会进行四舍五入处理。
浮点数与定点数对比:
- 浮点数相对于定点数的优点是在长度一定的情况下,浮点类型取值范围大,但是不精准,适用于需要取值范围大,又可以容忍微小误差的科学计算场景(比如计算化学、分子建模、流体动力学等)
- 定点数类型取值范围相对小,但是精准,没有误差,适合于对精度要求极高的场景(比如涉及金额计算的场景) ```sql use dbtest12;
CREATE TABLE test_decimal1( f1 DECIMAL, f2 DECIMAL(5,2) );
DESC test_decimal1;
INSERT INTO test_decimal1(f1) VALUES(123),(123.45);
SELECT * FROM test_decimal1;
INSERT INTO test_decimal1(f2) VALUES(999.99);
INSERT INTO test_decimal1(f2) VALUES(67.567);#存在四色五入
直接溢出
Out of range value for column ‘f2’ at row 1
INSERT INTO test_decimal1(f2) VALUES(1267.567);
进位溢出
Out of range value for column ‘f2’ at row 1
INSERT INTO test_decimal1(f2) VALUES(999.995);
演示DECIMAL替换DOUBLE,体现精度
ALTER TABLE test_double2 MODIFY f1 DECIMAL(5,2);
DESC test_double2;
SELECT SUM(f1) FROM test_double2;
SELECT SUM(f1) = 1.1,1.1 = 1.1 FROM test_double2; ```