在mysql中,decimal是一种定点数类型,主要用于存储需要高精度的数值,和浮点类型float、double不同,decimal在存储和计算时不会出现精度丢失的问题,非常适合存储金额、数量等要求精确的数值。

decimal的基本语法
decimal的定义语法格式如下:
DECIMAL(M, D)
其中两个参数的含义分别是:
- M:表示总位数,也就是整数部分和小数部分的总位数,取值范围是1到65,默认值是10。
- D:表示小数位数,也就是小数点后面的位数,取值范围是0到30,并且D的值不能超过M的值,默认值是0。
比如DECIMAL(10,2)就表示这个字段最多可以存储10位数字,其中小数部分占2位,整数部分最多占8位。
decimal的存储特性
decimal类型是定点存储,mysql会将数值按照字符串的形式存储,因此不会出现浮点类型常见的精度丢失问题。比如我们存储金额时,如果使用float类型存储0.1,可能会出现0.10000000000000001这类近似值,而decimal会精确存储0.1。
当插入的数值小数位数超过定义的D时,mysql会根据四舍五入的规则处理,如果四舍五入后总位数超过了M,则会报错。如果插入的数值整数部分的位数超过M-D,也会直接报错。
decimal的实际使用示例
创建包含decimal字段的表
我们先创建一个商品表,其中价格字段使用decimal类型存储,保留2位小数:
CREATE TABLE product (
id INT PRIMARY KEY AUTO_INCREMENT,
product_name VARCHAR(50) NOT NULL,
price DECIMAL(10, 2) NOT NULL COMMENT '商品价格,保留2位小数',
stock DECIMAL(8, 0) NOT NULL COMMENT '商品库存,整数'
);
插入数据操作
向product表中插入符合规则的测试数据:
-- 插入正常数据,小数位数为2,符合定义
INSERT INTO product (product_name, price, stock) VALUES ('笔记本电脑', 4999.99, 100);
-- 插入小数位数为3的数据,会四舍五入为2位小数
INSERT INTO product (product_name, price, stock) VALUES ('鼠标', 89.999, 500);
-- 插入整数价格,会自动补0到小数位
INSERT INTO product (product_name, price, stock) VALUES ('键盘', 299, 300);
执行上述插入语句后,第二条数据的price会被存储为90.00,第三条数据的price会被存储为299.00。
查询和计算操作
使用decimal字段进行查询和计算的示例如下:
-- 查询价格大于1000的商品 SELECT product_name, price FROM product WHERE price > 1000; -- 计算所有商品的总库存价值 SELECT SUM(price * stock) AS total_value FROM product;
上述计算过程中,decimal的精度会被保留,不会出现计算误差。
使用decimal的注意事项
- 如果不需要小数位,建议将D设置为0,比如存储整数的库存数量,使用
DECIMAL(8,0)即可,不需要使用int类型,避免后续业务扩展需要小数位时修改字段类型。 - 不要将decimal用于不需要高精度的场景,比如存储身高、体重这类可以有轻微误差的数值,使用float类型会更节省存储空间。
- 定义M和D的时候要根据实际业务需求设置,不要设置过大,避免浪费存储空间,也不要设置过小,导致业务数据无法存储。