zoukankan      html  css  js  c++  java
  • MySql中varchar(10)和varchar(100)的区别

    背景

    许多使用MySQL的同学都会使用到varchar这个数据类型。初学者刚开始学习varchar时,一定记得varchar是个变长的类型这个知识点,所以很多初学者在设计表时,就会把varchar(X)的长度设置的非常长,目的也是为了保证以后有更长的数据存储时,能更好的兼容。

    于是本来varchar(10)就可以满足当前的存储的长度需求了,改成了varchar(100)。

    那么疑问来了:

    既然是变长类型,varchar(10)和varchar(100)有什么区别?

    先举个例子:如果要存储'hello12345'这个字符串,使用varchar(10)varchar(100)存储,占用磁盘空间是一样的么?

    答案是:占用磁盘的存储空间是一样的。

    既然存储时磁盘占用空间一样,还有什么其他的区别吗?

    虽然使用varchar(100)varchar(10)存储'hello12345'字符串占用的磁盘空间一样,但是消耗的内存不一样,更长的列消耗的内存会更多。因为MySQL通常会分配固定大小的内存块来保存内部值。尤其是使用临时表进行排序会操作时,会消耗更多的内存。在使用磁盘进行排序时,也是一样。

    所以此时varchar(100) 会消耗更多的内存。

    varchar(10)和varchar(100)的优劣势是什么?

    因为涉及到文件排序或者基于磁盘的临时表时,更长的列会消耗更多的内存,所以在使用使用时,我们不能太过浪费内存空间,还是需要评估实际使用的长度来设置字符的长度。推荐冗余10%的长度(因业务而异)。

    所使用varchar(10)会更加节约内存空间,但是实际业务中字符长度一旦超过10就需要更改表结构,在表数据量特别大时,不易拓展

    而这时使用更长的列:varchar(100)无需更改表结构,业务拓展性更好

    参考:
    《高性能MySQL第3版》第四章

    欢迎关注我个人公众号:java之旅

  • 相关阅读:
    (转)二步实现 远程连接 阿里云SqlServer 2012 数据库服务器
    浅谈C#在网络波动时防重复提交
    面向 Kubernetes 编程: Kubernetes 是下一代操作系统
    C#并行编程(2):.NET线程池
    C#并行编程(1):理解并行
    iOS 动画总结----UIView动画
    iOS开发之各种动画各种页面切面效果
    iOS动画效果和实现
    iOS开发动画(Animation)总结
    iOS开发之传感器
  • 原文地址:https://www.cnblogs.com/chinaxieshuai/p/12703714.html
Copyright © 2011-2022 走看看