char()和VARCHAR()的主要区别是什么?

1、char的长度是不可变的,而varchar的长度是可变的

字段b:类型char(10),     值为:abc,存储为:abc             (abc+7个空格)

字段d:类型varchar(10), 值为:abc,存储为:abc (自动变为3个的长度)

 

2、超出长度自动截取

字段c:类型char(3),     值为:abcdefg,存储为:abc(defg自动删除)

字段e:类型varchar(3), 值为:abcdefg,存储为:abc (defg自动删除)

 

3、var(10)和char(10),都表示可存10个字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放10个

 

4、char最多可以存放255个字符

  varchar的最大长度为65535个字节,varchar可存放的字符数跟编码有关

  字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766个字符

  字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845个字符

 

5、char和varchar的最大长度限制是mysql规定的

 

posted @   254980080  阅读(14046)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示