mysql的decimal float double

https://www.cnblogs.com/xujishou/p/6307299.html

 

1 、double的存储值最大为16位,保留几位小数可以设置

      比如double(10,2),小数点的左右两边的位数加起来不能超过10位

2 、decimal 的最大存储值为38位,保留几位小数可以设置,

      比如decimal(10,2)的存储值为:左边最大值为7位,小数点候保留2位小数,加起来最大值为10位, 

     小数点的左右两边的位数加起来不能超过10位

 

MySQL中存在float,double等非标准数据类型,也有decimal这种标准数据类型。

其区别在于,float,double等非标准类型,在DB中保存的是近似值,而Decimal则以字符串的形式保存数值。
float,double类型是可以存浮点数(即小数类型),但是float有个坏处,当你给定的数据是整数的时候,那么它就以整数给你处理。这样我们在存取货币值的时候自然遇到问题,我的default值为:0.00而实际存储是0,同样我存取货币为12.00,实际存储是12。
幸好mysql提供了两个数据类型:decimal,这种数据类型可以轻松解决上面的问题:decimal类型被 MySQL 以同样的类型实现,这在 SQL92 标准中是允许的。他们用于保存对准确精度有重要要求的值,例如与金钱有关的数据。
 

数据定义

float(M,S) M为全长,S为小数点后长度。对于不精准的例子,网络上很多,Copy如下:

mysql> create table t1(c1 float(10,2), c3decimal(10,2)); 

Query OK, 0 rows affected (0.02 sec)

mysql> insert into t1 values(9876543.21, 9876543.12);                   

Query OK, 1 row affected (0.00 sec)

mysql> select * from t1;                        

+----------------+-----------------+

| c1                | c3                   |

+----------------+-----------------+

| 9876543.00 | 9876543.12 | 

+----------------+------------------+

2 rows in set (0.00 sec)

再举例: DECIMAL(5,2)

mysql> create table t1(id1 float(5,2) default null,id2 double(5,2) default null,
id3 decimal(5,2) default null );

mysql> insert into t1 values(1.2345,1.2345,1.2345);
Query OK, 1 row affected, 1 warning (0.04 sec)

mysql> show warnings;
+-------+------+------------------------------------------+
| Level | Code | Message |
+-------+------+------------------------------------------+
| Note | 1265 | Data truncated for column 'id3' at row 1 |
+-------+------+------------------------------------------+
1 row in set (0.00 sec)

 

1.2345 --- 小数点后最多2位,所以保存可以,自动四舍五入数据截断,但会报waning

12.34 --- OK

1234.5 --- 因为小数部分未满2位,要补0.所以保存应该1234.50。所以整个位数超出了5,保存报错。

1.2 --- 小数未满部分补0。按照1.20保存。

 

默认状态比较

浮点数如果不写经度和标度,会按照实际精度值保存,如果有精度和标度,则会自动将四舍五入后的结果插入,系统不会报错;定点数如果不写精度和标度,则按照默认值decimal(10,0) 来操作,如果数据超过了精度和标度值,系统会报错。

 

 

### MySQL 中 `FLOAT`、`DOUBLE` 和 `DECIMAL` 数据类型的区别 #### 存储方式与精度 - **`FLOAT` 类型**:采用单精度浮点数表示,占用4个字节。该类型能够提供大约7位有效数字的精度[^3]。由于其内部使用IEEE标准来表达数值,在某些情况下可能会引入舍入误差。 - **`DOUBLE` 类型**:双精度浮点数形式,占据8个字节的空间,可以支持高达15到17位的有效数字精度[^1]。 - **`DECIMAL(M,D)` 或者 `NUMERIC(M,D)` 类型**:这是一种固定长度的小数类型,其中 M 表示总的位数(包括整数部分和小数部分),D 则指定了小数点后的位数。这种类型的存储取决于定义时指定的最大宽度加上两个额外字节用于记录符号和其他信息[M+2][^2]。它能确保精确度不会丢失,并且非常适合处理货币金额或其他不允许有任何近似的情况。 #### 性能差异 当涉及到大量计算操作时,`FLOAT` 和 `DOUBLE` 可能会比 `DECIMAL` 更高效,因为硬件通常优化了对这两种浮点数的操作速度;然而,这并不意味着总是如此——具体表现还依赖于实际的应用环境以及所使用的数据库引擎版本等因素。 #### 应用场景 - 对于那些不需要绝对准确性但追求更高效率的应用程序来说,可以选择 `FLOAT` 或者 `DOUBLE` 来保存科学测量值或者其他非金融性质的数据集。 - 如果应用程序涉及财务报表、会计账目等需要严格控制四舍五入错误的地方,则应优先考虑使用 `DECIMAL` 类型以保持数据的一致性和可靠性[^5]。 ```sql CREATE TABLE financial_records ( id INT AUTO_INCREMENT PRIMARY KEY, amount DECIMAL(10, 2) NOT NULL -- 储存金额,最多有两位小数 ); INSERT INTO financial_records(amount) VALUES (1234.56); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值