oracle mysql gbk varchar varchar2
http://www.cnblogs.com/kxdblog/p/4042331.html
https://wenku.baidu.com/view/97524e0f844769eae009ed80.html
http://blog.csdn.net/lwei_998/article/details/7728173
char是定长的,varchar是变长的。varchar2应该是varchar的升级,似乎只有ORACLE才有,这里不作讨论。
char定长存储,速度快,但是存在一定的空间浪费,适用于字段不是很大,对速度要求高的场合。速度快是因为其在物理上是按定长存储的,这样,就可以根据偏移址一次取出固定长度的字符。
varchar变长存储,所以效率不如char。varchar在存储时,在物理上要先存储该字段的实际长度,然后才是内容。这样读取的时候,就要读取两次,一次读它的长度,然后才是内容。所以它的访问速度会比char慢一些。但它可以节省空间。
由于mysql自身的特点,如果一个数据表存在varchar字段,则表中的char字段将自动转为varchar字段。在这种情况下设置的char是没有意义的。所以要想利用char的高效率,要保证该表中不存在varchar字段;否则,应该设为varchar字段。
char
是定长的,
varchar
是变长的。
varchar2
应该是
varchar
的升级,似乎只
有
ORACLE
才有,这里不作讨论。
char
定长存储,速度快,但是存在一定的空间浪费,适用于字段不是很大,对
速度要求高的场合。
速度快是因为其在物理上是按定长存储的,
这样,
就可以根
据偏移址一次取出固定长度的字符。
varchar
变长存储,所以效率不如
char
。
varchar
在存储时,在物理上要先存储
该字段的实际长度,然后才是内容。这样读取的时候,就要读取两次,一次读它
的长度,然后才是内容。所以它的访问速度会比
char
慢一些。但它可以节省空
间。
由于
mysql
自身的特点,如果一个数据表存在
varchar
字段,则表中的
char
字
段将自动转为
varchar
字段。在这种情况下设置的
char
是没有意义的。所以要
想利用
char
的高效率,要保证该表中不存在
varchar
字段;否则,应该设为
varchar
字段。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具