mysql金钱字段decimal

本文通过创建MySQL表并插入相同数值,对比了float、decimal和float(10,0)三种数据类型的精度表现,揭示了decimal类型在处理精确数值时的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

新建表decimals

CREATE TABLE `decimals` (
  `id` int(11) NOT NULL,
  `name` varchar(255) DEFAULT NULL,
  `c1` float(10,2) DEFAULT NULL,
  `c2` decimal(10,2) DEFAULT NULL,
  `c3` float(10,0) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4

插入数据

INSERT INTO decimals ( c1, c2, c3 )
VALUES
	( 1234567.23, 1234567.23, 1234567.23 )

查看结果

使用decimal可以保证数据的精度

mysql> select * from decimals;
+----+------+------------+------------+---------+
| id | name | c1         | c2         | c3      |
+----+------+------------+------------+---------+
|  1 | NULL | 1234567.25 | 1234567.23 | 1234567 |
+----+------+------------+------------+---------+
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值