我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL数据类型DECIMAL用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL数据类型DECIMAL用法

前言: 

当我们需要存储小数,并且有精度要求,比如存储金额时,通常会考虑使用DECIMAL字段类型,可能大部分同学只是对DECIMAL类型略有了解,其中的细节还不甚清楚,本篇文章将从零开始,为你讲述DECIMAL字段类型的使用场景及方法。

1.DECIMAL类型简介

DECIMAL从MySQL 5.1引入,列的声明语法是DECIMAL(M,D)。NUMERIC与DECIMAL同义,如果字段类型定义为NUMERIC,则将自动转成DECIMAL。

对于声明语法DECIMAL(M,D),自变量的值范围如下:

  • M是最大位数(精度),范围是1到65。可不指定,默认值是10。
  • D是小数点右边的位数(小数位)。范围是0到30,并且不能大于M,可不指定,默认值是0。

例如字段 salary DECIMAL(5,2),能够存储具有五位数字和两位小数的任何值,因此可以存储在salary列中的值的范围是从-999.99到999.99。

2.DECIMAL使用实战

下面我们将创建测试表来验证DECIMAL字段类型的使用:

# 创建具有DECIMAL字段的表 验证decimal默认是decimal(10,0)
mysql> create table decimal_tb (col1 decimal,col2 decimal(5,2));
Query OK, 0 rows affected (0.04 sec)

mysql> show create table decimal_tb\G
*************************** 1. row ***************************
       Table: decimal_tb
Create Table: CREATE TABLE `decimal_tb` (
  `col1` decimal(10,0) DEFAULT NULL,
  `col2` decimal(5,2) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

# 插入数据测试 
# 结论:超出存储范围会报错,小数位不足会自动补0,首位数字为0自动忽略,小数位超出会截断 并按四舍五入处理。
mysql> insert into decimal_tb (col1,col2) values (100,100);
Query OK, 1 row affected (0.05 sec)

mysql> insert into decimal_tb (col2) values (1.23);
Query OK, 1 row affected (0.01 sec)

mysql> insert into decimal_tb (col2) values (10.2);
Query OK, 1 row affected (0.01 sec)

mysql> insert into decimal_tb (col2) values (09.9);
Query OK, 1 row affected (0.01 sec)

mysql> select * from decimal_tb;
+------+--------+
| col1 | col2   |
+------+--------+
|  100 | 100.00 |
| NULL |   1.23 |
| NULL |  10.20 |
| NULL |   9.90 |
+------+--------+
4 rows in set (0.00 sec)

mysql> insert into decimal_tb (col2) values (9999);
ERROR 1264 (22003): Out of range value for column 'col2' at row 1

mysql> insert into decimal_tb (col2) values (12.233); 
Query OK, 1 row affected, 1 warning (0.01 sec)

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

mysql> insert into decimal_tb (col2) values (12.2300);
Query OK, 1 row affected (0.01 sec)

# 变量范围测试
# 结论:M范围是1到65,D范围是0到30,且D不大于M
mysql> alter table decimal_tb add column col3 decimal(6,6);
Query OK, 0 rows affected (0.12 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col4 decimal(6,7); 
ERROR 1427 (42000): For float(M,D), double(M,D) or decimal(M,D), M must be >= D (column 'col4').

mysql> alter table decimal_tb add column col4 decimal(65,2);
Query OK, 0 rows affected (0.11 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col4 decimal(66,2);
ERROR 1426 (42000): Too-big precision 66 specified for 'col4'. Maximum is 65.

mysql> alter table decimal_tb add column col5 decimal(60,30); 
Query OK, 0 rows affected (0.13 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> alter table decimal_tb add column col6 decimal(60,31);
ERROR 1425 (42000): Too big scale 31 specified for column 'col6'. Maximum is 30.
3.DECIMAL使用总结

上面的内容从实战出发,介绍了DECIMAL类型的使用方法及注意事项,你可能也知道float、double这些浮点数类型,这两个同样可以存储小数,但这里不过多介绍,只是提醒大家float、double类型无法确保精度,很容易产生误差,特别是在求和计算的时候,所有当存储小数,特别是涉及金额时推荐使用DECIMAL类型。这里总结下使用DECIMAL应该注意的事项:

  • DECIMAL(M,D)中,M范围是1到65,D范围是0到30。
  • M默认为10,D默认为0,D不大于M。
  • DECIMAL(5,2)可存储范围是从-999.99到999.99,超出存储范围会报错。
  • 存储数值时,小数位不足会自动补0,首位数字为0自动忽略。
  • 小数位超出会截断,产生告警,并按四舍五入处理。
  • 使用DECIMAL字段时,建议M,D参数手动指定,并按需分配。

总结: 

本文比较简单实用,通读下来,你大概会明白DECIMAL字段的使用场景及注意事项,其实对于常见的字段类型,我们只需要了解其使用场景及注意事项即可,当我们建表时,能够快速选出合适的字段类型才是我们的目的,比如当我们需要存储小数时,能够使用DECIMAL类型并且根据业务需要选择合适的精度,这样我们的工作将很容易开展下去。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL数据类型DECIMAL用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

深入分析MySQL数据类型 DECIMAL

前言: 当我们需要存储小数,并且有精度要求,比如存储金额时,通常会考虑使用DECIMAL字段类型,可能大部分同学只是对DECIMAL类型略有了解,其中的细节还不甚清楚,本篇文章将从零开始,为你讲述DECIMAL字段类型的使用场景及方法。
2022-05-24

MySQL数据库的数据类型decimal详解

在MySQL数据库中,decimal数据类型用于存储精确的小数值。它比其他浮点类型(如float和double)更适合用于存储货币金额、利率等需要精确计算的数据。decimal数据类型的语法如下:DECIMAL(M, D)其中,M是总的数字
2023-09-14

mysql中decimal是什么数据类型

decimal 是 mysql 中用于存储定点小数的高精度数据类型。其特点包括:精度(由 (m, d) 指定)、范围、精度不丢失、存储空间。它常用于需要高精度货币计算的场景,如银行系统、会计软件和电子商务平台。什么是 MySQL 中的 DE
mysql中decimal是什么数据类型
2024-04-26

mysql数据库中Decimal类型怎么使用

今天小编给大家分享一下mysql数据库中Decimal类型怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1 背景数字
2023-06-29

mysql decimal数据类型转换的实现

最近在工作遇到数据库中存的数据类型是: decimal(14,4)遇到的问题是: 当我使用python 读取到内存中时,总是带着 decimal字符, 再写入其它mysql表中时,数据类型为int型,导致数据入库不成功.import pym
2022-05-24

详细解释MySQL中DECIMAL数据类型的使用

MySQL定点数类型DECIMAL用法详解在数据库中,经常需要处理精确的数值,例如货币金额或者科学计算等。为了保证计算准确性,MySQL提供了DECIMAL类型,用于存储精确的定点数值。本文将详细介绍MySQL中DECIMAL类型的用法,
详细解释MySQL中DECIMAL数据类型的使用
2024-02-24

数据库中Decimal类型怎么使用

数据库中的Decimal类型是一种精确的十进制数类型,用于存储需要保留小数位数的数值。在大多数数据库管理系统中,Decimal类型通常需要指定两个参数:精度(precision)和小数位数(scale)。精度表示整个数值的位数,包括整数和小
2023-08-14

mysql中decimal数据类型小数位填充问题详解

前言 在开发过程中,我们往往会用到decimal数据类型。因为decimal是MySQL中存在的精准数据类型。 MySQL中的数据类型有:float,double等非精准数据类型和decimal这种精准。 区别:float,double等非
2022-05-24

SQL decimal类型的用法是什么

SQL中的decimal类型用于存储精确的十进制数值。它可以指定数字的总位数和小数位数,以便在存储和计算过程中保持精确性。decimal类型的用法如下:1. 创建表时声明decimal列:CREATE TABLE table_name (c
2023-10-18

mysql中decimal类型怎么赋值

在MySQL中,Decimal类型可以使用以下语法进行赋值:CREATE TABLE table_name (column_name DECIMAL(precision, scale));INSERT INTO table_name (
mysql中decimal类型怎么赋值
2024-04-09

mysql的decimal类型如何给长度

MySQL的DECIMAL数据类型是用于存储精确的小数值的。在创建DECIMAL类型的列时,可以指定两个参数:精度(precision)和小数位数(scale)。精度(precision)指定了该列能够存储的数字的最大位数,包括整数和小数
mysql的decimal类型如何给长度
2024-04-09

mysql decimal类型判断是否为0

这篇文章详细阐述了如何判断MySQLDecimal类型是否为0。使用ISNULL和ISNOTNULL函数可检查値是否为NULL。COALESCE函数可与另一个非NULL值(例如0)比较。也可以使用等于(=)和不等于(<>)比较运算符,或使用大于(>)和小于(<)检查值。根据特定用例和性能要求,选择最合适的判断方法。
mysql decimal类型判断是否为0
2024-04-02

SQL中的real、float、decimal、numeric数据类型区别

概述:浮点数据类型包括real型、float型、decimal型和numeric型。浮点数据类型用于存储十进制小数。在SQL Server 中浮点数值的数据采用上舍入(Round up)的方式进行存储,所谓上舍入也就是,要舍入的小数部分不论其大小,只要是一个非
SQL中的real、float、decimal、numeric数据类型区别
2021-05-09

PHP中如何将Decimal类型转为整数类型

今天小编给大家分享一下PHP中如何将Decimal类型转为整数类型的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、Deci
2023-07-05

编程热搜

目录