MySql中varchar(10)和varchar(100)的区别和优缺点

背景

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

因而原本varchar(10)就能够知足当前的存储的长度需求了,改为了varchar(100)。性能

那么疑问来了:学习

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

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

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

既然存储时磁盘占用空间同样,还有什么其余的区别吗?排序

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

因此此时varchar(100) 会消耗更多的内存。字符串

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

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

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

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

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

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

相关文章
相关标签/搜索