MySQL tinyint(1) 、int(32) 与 varchar(255) 长度含义不同
创始人
2024-05-26 18:11:23
0

MySQL tinyint(1) 、int(32) 与 varchar(255) 长度含义不同

发现 tinyint(1),int(32) 和 varchar(255)

这里面的数字的含义是不同的。

先说数字类型 tinyint 和 int 等

他们能存储的字节大小是与类型绑定的,即定义了 tinyint 或者 int 就确定了能存储的空间大小。
tinyint(1) 和 tinyint(4) 都只能存储 1byte 的大小

int(32) 能存储 4byte 的大小,详细参见官方文档截图。

在这里插入图片描述
官方文档:https://dev.mysql.com/doc/refman/8.0/en/integer-types.html

数字 1,4,32 对于能存储的字节长度没有影响,参考 stackoverfolw 回答
在这里插入图片描述

但是 varchar(N) 的数字的含义却不太一样。 这里面 N 的含义是指字符的个数。

varchar 能够存储的最大长度是 65535 bytes。

以 utf8mb 编码为例,一个字符占用 4 字节。

理论上 N 能设置的最大值为 65535 / 4 = 16383

但是实际操作中,我最大能设置 16378 ,怀疑有 5 位用作校验或者其他用途了。(有时候还只能设置成 16377 这个暂时未知为什么

在这里插入图片描述

举个例子,varchar(2) 只能保存 2 个字符

在这里插入图片描述
再添加第三个字符的时候即报错
在这里插入图片描述

 Data truncation: Data too long for column 'text' at row 1

这个错误大家应该很熟悉了

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...