mysql的varchar到底能存多少个字符

mysql的varchar到底能存多少个字符

结论

(65535字节-其他列所占用的子节-varchar列长度-null标识占用字节数)/3,向下取整.

注意

  • 4.0版本及以下,MySQL中varchar长度单位是字节,如varchar(20),指的是20字节
  • 5.0版本及以上,MySQL中varchar长度单位是字符。如varchar(20),指的是20字符

测试环境

mysql5.7,存储引擎innodb,utf8字符集

复制代码
GBK编码:
一个英文字符占一个字节,中文2字节,单字符最大可占用2个字节。

UTF-8编码:
一个英文字符占一个字节,中文3字节,单字符最大可占用3个字节。

utf8mb4编码:
一个英文字符占一个字节,中文3字节,单字符最大占4个字节(如emoji表情4字节)。

单列

(65535-3)/3=21844

多列

(65535-其他列占用的总字节数)/3,向下取整

21844-255=21589

因为255也要占用额外的空间存储长度和null标识,实际需要255*3+长度+null标识

相关推荐
无敌的牛27 分钟前
redis学习过程
数据库·redis·学习
IT北辰30 分钟前
神通数据库管理系统V7.0.251210 for Windows(x86 64bit)安装部署
数据库·神通
北顾笙98042 分钟前
MySQL-day2
数据库·mysql
Demons_kirit1 小时前
新项目如何连接上自己本地的数据库
数据库
洪晓露2 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
程序猿乐锅2 小时前
【MySQL | 第八篇】MySQL 视图
数据库·mysql
jieyucx3 小时前
SQL 查询终极高阶通鉴:从零基础拆解到工业级多表联查、窗口函数与索引优化
数据库·sql
ai_coder_ai4 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql
AOwhisky5 小时前
Redis 学习笔记(第一期):概述、安装配置与核心理论
运维·数据库·redis·笔记·学习·云计算
ytttr8735 小时前
C# 定时数据库备份工具
开发语言·数据库·c#