varchar和char都表示字符类型,各自的特点如下:
一、char:
1、固定长度
特点:当输入字符小于指定长度时,用空格填充
优点:检索速度快
缺点:占用较多内存或者硬盘
2、其他
范围255,取值或者设置时自动去除末尾空格,
二、varchar:
1、可变长度
特点:当输入字符小于指定长度时,自动剪切掉多余部分,会使用1-3个字节来存储长度
优势:节省内存和硬盘空间,
缺点:检索新能较差,
2、其他
5以前版本:最大范围255,取值或者设置时去掉末尾空格,
5之后版本:最大范围65535,取值或者设置时保留末尾空格,保留长度=实际长度+1,且实际长度+1 < 设置长度
三、text与varchar
相同:存变长大数据,速度慢,不存在空间浪费,不处理尾部空格,上限65535,
不同:text会用额外空间存放数据长度,可以全部使用65535,而varchar占用内部3个字节放长度,可全部使用65532,
关系:当varchar长度达到一定时,系统自动转成text,检索性能也并无不同,
小结:
varchar:适用于长度经常变化又不确定时,
char:适合保存MD5后的哈希值或经常改变的值,因为固定的行不容易产生碎片。
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】开源 Linux 服务器运维管理面板 1Panel V2 版本正式发布
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步