DECIMAL和NUMERIC

MySQL支持两种定点数类型:DECIMAL和NUMERIC,而NUMERIC实现为DECIMAL,因此MySQL中DECIMAL和NUMERIC等价相同。

如使用下面建表语句:

CREATE TABLE tb003(
id INT PRIMARY KEY,
c1 DECIMAL(20,5),
c2 NUMERIC(18,5)
)ENGINE=INNODB DEFAULT CHARSET=utf8;

表创建完成后显示的建表语句:

CREATE TABLE `tb003` (
`id` INT(11) NOT NULL,
`c1` DECIMAL(20,5) DEFAULT NULL,
`c2` DECIMAL(18,5) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB DEFAULT CHARSET=utf8;

当列被定义为DECIMAL(5,2)时,5为精度,2为刻度,精度表示值存储的有效位数,刻度表示小数点后可存储的位数。
当列被定义为DECIMAL(5,2)时,该列存储范围为-999.99值999.99。

定点数存储空间

定点数在存储时将整数部分和小数部分分开存储,每9位10进制数据需要4个byte来存储,不满9位的部分使用不同字节来存储:

如列类型为DECIMAL(30,4)时:

1、整数部分长度=30-4=26=9+9+8,整数部分需要存储空间=4+4+4=12
2、小数部分长度=4,小数部分需要存储空间=2
因此列类型为DECIMAL(30,4)时,其所需存储空间为12+2=14。

PS1:在查看执行计划时,key_len列表示索引列的长度,对于二级索引,该长度仅为索引列的长度,不包含主键列长度。在类型为DECIMAL(30,4)  NOT NULL 的列上建索引,则key_len列显示为14。如果类型为DECIMAL(30,4)  NULL的列上建索引,则key_len显示为15,需要额外的1个字节表示是否为NULL

存储空间溢出问题

在严格SQL模式下(sql_mode = 'TRADITIONAL'),发生存储值溢出问题会报错且操作无法执行成功。
在非严格SQL模式下(sql_mode = 'TRADITIONAL'),发生存储值溢出问题时会有警告(1265,Data truncated)且操作能执行完成,但:
1、如果值超过存储范围,则会当做该类型最大值处理,如对类型DECIMAL(5,2)的列插入10000,最终插入值为999.99。
2、如果小数部分超过存储范围,则会进行四舍五入处理,如对类型DECIMAL(5,2)的列插入10.555,最终插入值为10.56。

使用BIGINT来存放“定点数”

某些文章中会以各种理由而建议使用BIGINT类型来存放与钱相关的数据:
理由1:使用对于DECIMAL(18,2)来存放时,会导致某些统计数据不准如银行计算利息。
这并不是DECIMAL的问题,而是程序设计不严谨导致,以存钱利息为例,单个用户的利息计算最终精确到分,分以后部分被抹去,但统计多个用户时,
分以后部分又被累计相加,导致总金额"变多"。
解决办法:增大数据类型精度,调整统计算法。

理由2:使用BIGINT能有效降低存储空间
BIGINT使用8字节来存储数据,数据范围为-9223372036854775808 到 9223372036854775807(922亿亿,整数部分19位),
如果我们将数据扩大10000倍来存放,那么BIGINT类型对应存放数据类型为DECIMAL(19,4),其存储空间为10字节,降低2个字节。

理由3:不同数值类型计算对CPU的消耗不同。
以主流服务器CPU运算能力来看,不同数值类型造成的CPU影响有限。

受FLOAT和DOUBLE两种浮点数类型不能精确存储数据的影响,导致部分研发在不明真相情况下会排斥使用DECIMAL类型,但存在即合理,每种数据类型都有其优缺点和适用场景

MySQL DataType--定点数(Fixed-Point Types)学习的更多相关文章

  1. MySQL大表优化方案 Mysql的row_format(fixed与dynamic)

    转自:https://mp.weixin.qq.com/s/VY69wWlrVLjRtKU7ULrYGw 当MySQL单表记录数过大时,增删改查性能都会急剧下降,可以参考以下步骤来优化: 单表优化 除 ...

  2. mysql与sql server参照对比学习mysql

    mysql与sql server参照对比学习mysql 关键词:mysql语法.mysql基础 转自桦仔系列:http://www.cnblogs.com/lyhabc/p/3691555.html ...

  3. MySQL DataType--浮点数(Floating-Point Types)学习

    浮点数(Floating-Point Types) MySQL支持两种浮点数类型来表示近似值:1.FLOAT,单精度浮点数,使用4字节存储,存储数据范围3.402823466E+38 - -1.175 ...

  4. 《MySQL必知必会》学习笔记——第1章 了解SQL

    第1章 了解SQL 本章将介绍数据库和SQL,它们是学习MySQL的先决条件. 1.1 数据库基础 你正在阅读本书,这表明你需要以某种方式与数据库打交道.在深入学习MySQL及其SQL语言的实现之前, ...

  5. MySQL分表(Partition)学习研究报告

    最近在开发一个新的项目,可能会产生大数据量,需要对部分表进行分表操作,故来研究学习MySQL的分表功能. 由于实验报告已经写成Exlce文件了,各位看过就直接下载吧:MySQL分表分析报告.xls 以 ...

  6. MySQL 体系结构以及各种文件类型学习汇总 (转)

    1,mysql体系结构 由数据库和数据库实例组成,是单进场多线程架构. 数据库:物理操作系统文件或者其它文件的集合,在mysql中,数据库文件可以是frm.myd.myi.ibd等结尾的文件,当使用n ...

  7. 《mysql必知必会》学习_第八章_20180730_欢

    第八章学习LIKE操作符,百分百(%)通配符,下划线(_)通配符 P47 select prod_id,prod_name from products where prod_name LIKE 'je ...

  8. Mysql的row_format(fixed与dynamic)

     在mysql中, 若一张表里面不存在varchar.text以及其变形.blob以及其变形的字段的话,那么张这个表其实也叫静态表,即该表的row_format是fixed,就是说每条记录所占用的字节 ...

  9. MySQL系统变量auto_increment_increment与auto_increment_offset学习总结

    在MySQL中,系统变量auto_increment_increment与auto_increment_offset是与自增列相关的两个参数变量.在官方文档中,将其划分为Replication Mas ...

随机推荐

  1. SQL存储实现将JSON自动转化成SQL数据列

    CREATE PROCEDURE sp_GetJsonFields ( @Json VARCHAR(MAX) ) AS BEGIN SELECT @Json=REPLACE(@Json,'{','') ...

  2. npm link用法总结

    npm link用来在本地项目和本地npm模块之间建立连接,可以在本地进行模块测试 具体用法: 1. 项目和模块在同一个目录下,可以使用相对路径 npm link ../module 2. 项目和模块 ...

  3. RunTime总结:

    oc动态性, 运行时将代码转化为runtime的C代码 RunTime运行流程: 生成对应objc_msgSend方法 isa指针查看当前类有没有这个方法, 之后寻找父类, 每个方法SEL(方法选择器 ...

  4. java Random 随机密码

    /** * Created by xc on 2019/11/23 * 生成随机密码:6位数字 */public class Test7_4 { public static void main(Str ...

  5. Hadoop深入学习之HA

    1. 基本原理 2.x版本中,HDFS架构解决了单点故障问题,即引入双NameNode架构,同时借助共享存储系统来进行元数据的同步,共享存储系统类型一般有几类,如:Shared NAS+NFS.Boo ...

  6. Windows删除文件夹下的指定格式文件(递归删除)

    问题描述: 今天遇到一个需求,需要对文件夹进行文件筛选.目录结构较为复杂(目录较多,层次较深),数据量较大(总共60GB左右). 鉴于上述情况,直接排除了人工处理方式(否则小伙伴们会打死我的). 解决 ...

  7. Redis 分布式锁,C#通过Redis实现分布式锁(转)

    目录(?)[+] 分布式锁一般有三种实现方式: 可靠性   分布式锁一般有三种实现方式: 1. 数据库乐观锁; 2. 基于Redis的分布式锁; 3. 基于ZooKeeper的分布式锁.本篇博客将介绍 ...

  8. Java 文件完整性校验 MD5 sha1 sha256 sha224 sha384 sha512

    由于项目中需要使用文件做备份,并且要提供备份文件的下载功能.备份文件体积较大,为确保下载后的文件与原文件一致,需要提供文件完整性校验. 网上有这么多此类文章,其中不少使用到了 org.apache.c ...

  9. Windows Server 2008 R2 IIS7.5配置FTP图文教程

    本文为大家分享了IIS 配置FTP 网站的具体过程,供大家参考,具体内容如下 说明:服务器环境是Windows Server 2008 R2,IIS7.5. 1. 在 服务器管理器的Web服务器(II ...

  10. 研发的困境----DEVOPS

    1.研发的困境 互联网的环境 互联网这个环境比较特别,包括现在不只是互联网,就算是被互联网赋能的这些“互联网+”的企业也在改变,用户在发生变化,用户构成的群体在发生变化,群体造成场景的变化,场景营造新 ...