MySQL文档说`decimal` 的最大位数是 `65`,什么意思?
一、MySQL文档说decimal 的最大位数是 65,什么意思
DECIMAL从MySQL 5.1引入,列的声明语法是DECIMAL (M,D)。NUMERIC与DECIMAL同义,如果字段类型定义为NUMERIC,则将自动转成DECIMAL。对于声明语法DECIMAL (M,D),自变量的值范围如下:M是最大位数(精度),范围是1到65。可不指定,默认值是10。
— #1 问题分析
— 65是最大的位数(含整数和小数点部分)。
— #2 代码示例
CREATE TABLE tb_datatype (
id int(11) DEFAULT NULL,
smallintcol smallint(6) DEFAULT NULL,
smallintcol2 smallint(3) DEFAULT NULL,
decimalcol decimal(65,38) DEFAULT NULL,
smallintcol3 smallint(3) unsigned zerofill DEFAULT NULL,
smallintcol4 smallint(5) unsigned DEFAULT NULL,
seq int(11) NOT NULL AUTO_INCREMENT,
PRIMARY KEY (seq)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb3
INSERT INTO tb_datatype(id) VALUES(1);
— #2.1 整数部分不能超过27
UPDATE tb_datatype
SET decimalcol= REPEAT(9,28)
WHERE id = 1
> 1264 – Out of range value for column ‘decimalcol’ at row 1
> 时间: 0s
— #2.2 整数部分最大到27
UPDATE tb_datatype
SET decimalcol= REPEAT(9,27)
WHERE id = 1
> Affected rows: 1
> 时间: 0.058s
— #2.3 小数点后部分不能超过38
UPDATE tb_datatype
SET decimalcol= CONCAT(REPEAT(9,27),’.’,REPEAT(9,39))
WHERE id = 1
> 1264 – Out of range value for column ‘decimalcol’ at row 1
> 时间: 0s
— #2.4 小数点后部分最大到38
UPDATE tb_datatype
SET decimalcol= CONCAT(REPEAT(9,27),’.’,REPEAT(9,38))
WHERE id = 1
> Affected rows: 0
> 时间: 0s
— # 2.5 查看结果
SELECT decimalcol
FROM tb_datatype WHERE id=1
延伸阅读:
二、数据库和 SQL 概念
数据库(Database)是按照数据结构来组织、存储和管理数据的仓库,它的产生距今已有六十多年。随着信息技术和市场的发展,数据库变得无处不在:它在电子商务、银行系统等众多领域都被广泛使用,且成为其系统的重要组成部分。
数据库用于记录数据,使用数据库记录数据可以表现出各种数据间的联系,也可以很方便地对所记录的数据进行增、删、改、查等操作。
结构化查询语言(Structured Query Language)简称 SQL,是上世纪 70 年代由 IBM 公司开发,用于对数据库进行操作的语言。更详细地说,SQL 是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统,同时也是数据库脚本文件的扩展名。

相关推荐HOT
更多>>
为什么TDD是敏捷的核心实践?
一、提高软件质量TDD的核心思想是在编写功能代码之前,先编写测试代码,并通过测试代码来驱动功能代码的编写。这种测试驱动的开发方式有助于提...详情>>
2023-10-15 22:30:43
什么是Android逆向?
一、Android逆向的概念Android逆向指的是对Android应用进行逆向分析、破解和修改的过程。逆向工程是通过分析应用程序的二进制代码、数据和文件...详情>>
2023-10-15 17:31:51
MySQL文档说`decimal` 的最大位数是 `65`,什么意思?
一、MySQL文档说decimal 的最大位数是 65,什么意思DECIMAL从MySQL 5.1引入,列的声明语法是DECIMAL (M,D)。NUMERIC与DECIMAL同义,如果字段类...详情>>
2023-10-15 16:14:32
Oracle数据库运行越来越慢,应该怎么优化?
一、Oracle数据库运行越来越慢的优化方法1、应用层优化应用程序的设计和开发中,可以采用合理的数据查询语句来减少数据库的 I/O 操作次数,例如...详情>>
2023-10-15 15:48:10热门推荐
为什么公司内同级别的管理岗要比技术岗收入高?
沸Prince2跟pmp有什么区别?
热JAVA为什么要用多态,什么是多态?
热为什么TDD是敏捷的核心实践?
新番茄工作法的优点和缺陷都有哪些?
Go语言标准库中最常用的标识符是什么?
C语言和其他高级语言的最大区别是什么?
为什么大数据系统会部分取代关系型数据库?
怎么利用hadoop搭建自己的云计算?
MYSQL的幻读和我们平常说的幻读有什么区别?
BIOS、UEFI、MBR、GPT、GRUB是什么?
在sql语言中,数据操纵与数据控制有何区别?
gzip解压NR库的时候,报错格式违法怎么办?
什么是Android逆向?
技术干货






