MySQL中char与varchar数据类型选择原则

原创 2016年05月31日 15:37:15

很多地方在分析char与varchar数据类型选择原则上,往往忽略了存储引擎。事实上,我们应当根据选定的存储引擎,确定如何选择合适的数据类型。

char与varchar比较

char(3) 实际存储字符长度 varchar(3) 实际存储字符长度
’ ‘ 3 1
‘ab’ ‘ab ‘ 3 ‘ab’ 3
‘abc’ ‘abc’ 3 ‘abc’ 4
‘abcdefg’ ‘abc’ 3 ‘abc’ 4

总结:从上表可以看出,char属于定长的。
char属于定长类型,varchar属于非定长类型,varchar属于变长。可能有人会问为什么varchar长度比数据长度大呢?因为VARCHAR保存时用一个字节或两个字节长的前缀+数据。如果VARCHAR列声明的长度大于255,长度前缀是两个字节,否则是一个字节。

MyISAM存储引擎

MyISAM数据表,最好使用固定长度的数据列代替可变长度的数据列。

InnoDB 存储引擎

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

MEMORY存储引擎

MEMORY数据表目前都使用固定长度的数据行存储,因此无论使用CHAR或VARCHAR列都没有关系。两者都是作为CHAR类型处理的。

误区

1.我们都知道,utf-8的中文占3个字节,gbk占两个字节,那么varchar(20)是不是只能存储20个字节,即存储6个汉字呢?
答:不是这样的,(网上说5.0之前版本是这样的,没有测试)。mysql varchar(20) 不管中文还是英文都能存20个,但varchar字段的最大长度跟编码有关,如果是utf-8,那么大概65535/3,如果是gbk,那么大概65535/2

版权声明:本文为博主原创文章,转载请附带原文网址,谢谢。 举报

相关文章推荐

python网络爬虫抓取动态网页并将数据存入数据库MySQL

简述以下的代码是使用python实现的网络爬虫,抓取动态网页 http://hb.qq.com/baoliao/ 。此网页中的最新、精华下面的内容是由JavaScript动态生成的。审查网页元素与网页...

MySQL数据类型char与varchar中数字代表的究竟是字节数还是字符数?

实例是最好的说明,所以,废话少说,看表看例子~mysql> show create table test_varchar_utf8\G *************************** 1. r...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

MySQL数据类型 CHAR和VARCHAR

MySQL数据类型 CHAR和VARCHAR

SQL Server中字段数据类型char nchar varchar nvarchar的区别

在SQL Server中,当我们设置字符型字段的时候,往往有很多个数据类型供我们选择,如:char nchar varchar nvarchar等,那么我们到底应该选择哪一个呢?下面就一一来描述其区别...

SQL中数据类型char/varchar/nvarchar/nchar/text/ntext的区别

1、CHAR。CHAR存储定长数据很方便,CHAR字段上的索引效率级高,比如定义char(10),那么不论你存储的数据是否达到了10个字节,都要占去10个字节的空间,不足的自动用空格填充,所以在读取的...

SQL Server 2005数据类型char,varchar,text ,nchar,nvarchar,ntext 等学习拾遗

在数据库设计时我们常常为数据类型而烦恼,但是当你熟悉了之后就不再烦恼了,看看吧,看看对你有没有帮助。 char,varchar,text ,nchar,nvarchar,ntext 等学习拾遗,...

mysql列类型char,varchar,text,tinytext,mediumtext,longtext的比较与选择

文章出处:http://baifjece.blog.163.com/blog/static/33794654201271022336541/ 储存不区分大小写的字符数据 TINYTEX...
  • YDYKL
  • YDYKL
  • 2012-08-26 15:18
  • 1412

MySQL数据类型varchar详解

这篇文章详细介绍了MySQL数据类型varchar,探讨varchar到底能存多长的数据、InnoDB和MyISAM中的varchar等问题,需要的朋友可以参考下
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)