全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

MySQL文档说`decimal` 的最大位数是 `65`,什么意思?

发布时间:2023-10-13 19:43:49
发布人:xqq

一、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 是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统,同时也是数据库脚本文件的扩展名。

#it技术干货

相关文章

软件开发公司能开发哪些类型的app软件?

软件开发公司能开发哪些类型的app软件?

2023-10-13
Win10下Oracle 11g 数据库突然连接失败怎么办?

Win10下Oracle 11g 数据库突然连接失败怎么办?

2023-10-13
oracle数据库库中两个表之间怎么同步数据?

oracle数据库库中两个表之间怎么同步数据?

2023-10-13
access数据库中的round函数是什么意思?

access数据库中的round函数是什么意思?

2023-10-13

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取