当前位置: 首页 > news >正文

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

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

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

http://www.lryc.cn/news/18804.html

相关文章:

  • 搜索旋转排序数组、路径总和 II、拆分数字
  • QT自绘标题和边框
  • 数据库浅谈之 LLVM
  • Unable to connect to Redis无法连接到Redis
  • Feign、Ribbon、Hystrix
  • SpringCloud - Nacos注册发现
  • Socket编程、协议理解
  • Idea集成码云
  • 并发编程学习篇ReentrantLock设计思想剖析
  • 区分效度全流程分析
  • 【华为OD机试模拟题】用 C++ 实现 - 找数字(2023.Q1)
  • 从0开始写Vue项目-Vue实现用户数据批量上传和数据导出
  • 企业容器云管理平台选型指南
  • OpenGL超级宝典学习笔记:着色器存储区块、原子内存操作、内存屏障
  • SpringMVC框架知识详解(入门版)
  • 25-动画和过渡
  • Linux 操作系统原理 — 虚拟内存管理
  • 保持超低温环境新方法:功耗降至十分之一!
  • 论文投稿指南——中文核心期刊推荐(音乐)
  • es-10搜索推荐suggest
  • VMware ESXi 7.0 Update 3k - 领先的裸机 Hypervisor (sysin Custom Image)
  • JVM整体分析篇
  • 【Python入门第十七天】Python While 循环
  • 怎样激发读者好奇心?短视频营销之场景化
  • 【LeetCode】剑指 Offer 14- II. 剪绳子 II p96 -- Java Version
  • 【红黑树】红黑树插入操作相关的细节和疑难拆解分析
  • 字符串匹配--strstr函数的模拟实现思路和代码
  • 【ArcGIS Pro二次开发】(7):地图(Map)的基本操作
  • python 自动化测试 pytest 的使用
  • 闭包(回顾)