Processing math: 100%

char与varchar区别(MYISAM)

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

Char属于固定长度的字符类型,而varchar属于可变长的字符类型。

下表将各种字符串值保存到char(4)varchar4)列后的结果,说明了charvarchar之间的差别

Char(4)

存储需求

Varchar (4)

存储需求

‘’

     

4字符节

‘’

1字符节

‘ab’

‘ab   

4字符节

‘ab ’

3字符节

‘abcd’

‘abcd’

4字符节

‘abcd’

5字符节

‘abcdefgh’

‘abcd’

4字符节

‘abcd’

5字符节

请注意,最后一行的值只适用于非“严格模式”时,如果mysql运行在严格模式,超过列长度的值将不会保存,并且会出现错误提示。

         char(4)varchar(4)列检索的值并不总是相同,因为检索事从char列删除了尾部的空格。

         由于char是固定长度的,所以他的处理速度比varhcar快的多,但是其缺点是浪费存储空间,程序需要对尾行空格进行处理,所以对于哪些长度变化不大并且对查询速度要求较高的数据可以考虑使用char类型存储

         另外,随着mysql版本的不断升级,varchar数据类型的性能也在不断改进并提高,所以在许多应用中,varvhar类型被更多使用

         mysql中,不同的存储引擎对charvarchar的使用原则有所不同,这里简单概括若下:

  Myisam存储引擎:建议使用固定长度的数据列代替可变长的数据列

  Memory存储引擎:目前都使用固定长度的数据行存储,因此无论使用char varchar列都没有关系,两者都是作为char类型处理

  Innodb存储引擎:建议使用varchar类型。对于innodb数据表,内部的行存储格式没有区分固定长度和可变长度列(所有数据行都使用指向数据列值的头指针),因此在本质上,使用固定长度的char列不一定比使用可变长度varchar的性能要好,因此,主要的性能因素是数据行使用的存储总量,由于char平均占用的空间多于varchar,因此使用varchar来最小化需要处理的数据行的存储总量和磁盘I/O是比较好的。

上面来自网易《深入浅出MYSQL数据库开发、优化与管理维护》

以下是测试过程,针对MYISAM,5.5.19 MySQL Community Server (GPL):

表结构

 

插入100万条记录

DELIMITER USEtest


DROP PROCEDURE IF EXISTS `test1`CREATEDEFINER=admin@


DELIMITER ;

 

DELIMITER USEtest


DROP PROCEDURE IF EXISTS `test2`CREATEDEFINER=admin@


DELIMITER ;

[root@vm01 test]# ll -h |grep test
-rw-rw---- 1 mysql mysql 8.5K 04-01 17:16 test1.frm
-rw-rw---- 1 mysql mysql  19M 04-01 17:20 test1.MYD
-rw-rw---- 1 mysql mysql  17M 04-01 17:20 test1.MYI

-rw-rw---- 1 mysql mysql 8.5K 04-01 17:16 test2.frm
-rw-rw---- 1 mysql mysql  20M 04-01 17:26 test2.MYD
-rw-rw---- 1 mysql mysql  12M 04-01 17:26 test2.MYI

char表数据+主键+索引=19M+17M=36M

varchar表数据+主键+索引=20M+12M=32M

=====================================================================

下面测试不带索引的。

插入100万条记录

-rw-rw---- 1 mysql mysql 8.5K 04-01 17:44 test1.frm
-rw-rw---- 1 mysql mysql  19M 04-01 18:01 test1.MYD
-rw-rw---- 1 mysql mysql 9.8M 04-01 18:01 test1.MYI

-rw-rw---- 1 mysql mysql 8.5K 04-01 17:44 test2.frm
-rw-rw---- 1 mysql mysql  20M 04-01 18:04 test2.MYD
-rw-rw---- 1 mysql mysql 9.9M 04-01 18:04 test2.MYI

char表数据+主键=19M+9.8M=28.8M

varchar表数据+主键=20M+9.9M=29.9M

 

=====================================================================

下面测试不带主键和索引的。

 

插入100万条记录

[root@vm01 test]# ll -h | grep test
-rw-rw---- 1 mysql mysql 8.5K 04-01 18:08 test1.frm
-rw-rw---- 1 mysql mysql  19M 04-01 18:10 test1.MYD
-rw-rw---- 1 mysql mysql 1.0K 04-01 18:10 test1.MYI

-rw-rw---- 1 mysql mysql 8.5K 04-01 18:08 test2.frm
-rw-rw---- 1 mysql mysql  20M 04-01 18:11 test2.MYD
-rw-rw---- 1 mysql mysql 1.0K 04-01 18:11 test2.MYI

char表数据=19M

varchar表数据=20M

=====================================================================

总结:针对MYISAM引擎,如果使用varchar字符类型,增加索引的容量要小于不加索引的。

 


本文转自 liang3391 51CTO博客,原文链接:http://blog.51cto.com/liang3391/823326


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
344
分享
相关文章
|
1月前
|
SQL
【YashanDB知识库】通过触发器复制varchar(4000 char)列的数据导致乱码
【YashanDB知识库】通过触发器复制varchar(4000 char)列的数据导致乱码
|
2月前
|
SQL
【YashanDB 知识库】通过触发器复制 varchar(4000 char) 列的数据导致乱码
**简介:** 某客户在使用触发器将表 A 的 varchar(4000 char) 列数据复制到表 B 时,出现数据乱码且不一致的问题。经分析,YashanDB 在处理触发器场景下的 varchar(4000 char) 列数据复制时存在机制错误,影响所有版本。建议将列长度修改为 varchar(2000 char) 或更小以规避问题。通过特定 SQL 可验证该问题是否存在。
|
2月前
|
SQL
【YashanDB 知识库】通过触发器复制 varchar(4000 char) 列的数据导致乱码
**问题简介:** 客户在使用触发器将表 A 中 varchar(4000 char) 列的数据复制到表 B 时,发现表 B 中的数据出现乱码且与表 A 不一致。此问题影响所有 YashanDB 版本,原因是 YashanDB 在处理触发器场景下的大长度 varchar 数据复制时存在机制错误。为避免该问题,建议将列长度修改为 varchar(2000 char) 或更小。数据正确性无法保证,需谨慎处理。 **验证方法:** 可通过创建表 A 和 B 及相应触发器进行测试。
【YashanDB 知识库】通过触发器复制 varchar(4000 char) 列的数据导致乱码
|
11月前
|
char *str,char &str,char *& str和char str的区别
char *str,char &str,char *& str和char str的区别
263 0
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
本篇文章来讨论MySQL字段的字符类型选择并深入实践char与varchar类型的区别以及在千万数据下的性能测试
MySQL字段的字符类型该如何选择?千万数据下varchar和char性能竟然相差30%🚀
|
11月前
|
5. CHAR和VARCHAR的区别?
`CHAR`和`VARCHAR`在数据库中有所不同:`CHAR`长度固定,用空格填充,存储效率高,英文占1字节,汉字占2字节;而`VARCHAR`长度可变,节省空间,英文和汉字都占2字节。
112 0
|
11月前
|
面试题:char和varchar的区别?
字节面试题:char和varchar的区别?
210 0

热门文章

最新文章