推荐链接:
总结——》【Java】
总结——》【Mysql】
总结——》【Redis】
总结——》【Kafka】
总结——》【Spring】
总结——》【SpringBoot】
总结——》【MyBatis、MyBatis-Plus】
一、作用
存储精确的数值
二、语法
decimal(p,d) 存储d位小数的p位数
| 参数 | 描述 | 默认值 | 取值范围 |
|---|---|---|---|
| p | 最大位数(包含小数点后的位数) | 10 | 1~65 |
| d | 小数位数(小数点后的位数) | 0 | 0~30 |
三、示例
| 示例 | 最大位数 | 整数位数 | 小数位数 | 取值范围(UNSIGNED) |
|---|---|---|---|---|
| decimal | 10 | 10 | 0 | -9999999999~9999999999 |
| decimal(3) | 3 | 3 | 0 | -999~999 |
| decimal(5,2) | 5 | 3 | 2 | -999.99~999.99 |
| decimal(7,6) | 7 | 1 | 6 | -9.999999~9.999999 |
-- 创建表,定义数据类型
CREATE TABLE `test` (
`id` int NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`area` decimal(10, 1) DEFAULT NULL COMMENT '面积',
PRIMARY KEY (`id`)
) COMMENT='测试表';
-- 修改数据类型
ALTER TABLE `test`
MODIFY COLUMN `area` decimal(5, 2) NULL DEFAULT NULL COMMENT '面积';
-- 插入数据
INSERT INTO test ( area ) VALUES ( 500.34 ),( 400 );
-- 查询数据
select * from test;
-- 取值范围之内,小数位多了,进行四舍五入
-- 取值范围之外,直接报错:Out of range value
-- 结果:500.34
INSERT INTO test ( area ) VALUES ( 500.344 );
-- 结果:500.35
INSERT INTO test ( area ) VALUES ( 500.349 );
-- 直接报错:1264 - Out of range value for column 'area' at row 1
INSERT INTO test ( area ) VALUES ( 5000.34 );


本文详细介绍了MySQL中decimal数据类型的使用方法,包括其作用、语法及具体的示例应用,并通过创建表、修改字段、插入数据等操作展示了decimal类型的特性。
2170

被折叠的 条评论
为什么被折叠?



