MySql中varchar(10)和varchar(100)的区别

MySQL的varchar(10)和varchar(100)在存储相同字符串时,磁盘占用相同但内存消耗不同,更长的列会消耗更多内存,尤其是在涉及排序和临时表时。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版》第四章***

### MySQL 中 `VARCHAR` `TEXT` 的区别及适用场景 #### 1. 存储容量 `VARCHAR` 数据类型适用于存储可变长度的字符串,其最大长度为 65,535 字节(受限于行大小)。然而,在实际应用中,单行数据的最大长度不能超过 65,535 字节[^2]。相比之下,`TEXT` 类型能够存储更大的文本数据,具体来说,它的最大长度可达 65,535 字符(依据具体的子类型如 TINYTEXT、TEXT、MEDIUMTEXT 或 LONGTEXT 而有所不同)[^4]。 #### 2. 性能影响 当涉及到性能时,`VARCHAR` 更具优势。因为 `VARCHAR` 的数据通常存储在表的页内,访问速度较快;而 `TEXT` 类型的数据可能会被存储到页外区域,这可能导致额外的磁盘 I/O 开销,从而降低查询效率[^3]。 #### 3. 查询与索引 `VARCHAR` 支持完整的索引功能,并且可以根据需要创建前缀索引以提高性能。另一方面,虽然 `TEXT` 列也可以建立索引,但仅限于定义一个较短的前缀作为索引部分,而且全文索引更适合用于 `TEXT` 类型的大规模文本检索。 #### 4. 使用场景分析 - **`VARCHAR` 的典型应用场景** 对于那些长度变化不大或者具有明确上限需求的小至中等长度字符串非常适合采用 `VARCHAR` 来保存,比如用户的姓名、电子邮件地址或是商品名称等等。 - **`TEXT` 的主要用途** 如果预计某些字段的内容将会很长——例如博客帖子内容、复杂的 JSON 文档或者其他形式的大段文字描述,则应该考虑选用 `TEXT` 类型来满足这些情况下的存储需求[^3]^。 ```sql -- 创建包含 VARCHAR TEXT 字段的例子 CREATE TABLE example_table ( id INT AUTO_INCREMENT PRIMARY KEY, short_text VARCHAR(255), -- 小型文本字段 long_text TEXT -- 大型文本字段 ); ``` #### 结论 综上所述,选择合适的 MySQL 字符串类型取决于特定的应用程序需求以及预期的工作负载特性。通过理解两者之间的差异并合理规划数据库结构中的每一项决策要素,可以有效提升系统的整体效能表现。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值