Mysql 的char 和varchar的的区别

1、char 和varchar 区别

下面以utf8字符集为例,char和varchar的占比计算,如下图
valueChar(5)bytesVarchar(5)bytesVarchar(100)bytes
‘’‘   ’15‘’1‘’1
‘abcd’‘abcd ’15‘abcd’13‘abcd’13
'abcde''abcde'15'abcde'16'abcde'16

        varchar使用额外的1到2字节来存储值得长度。如果列的最大长度小于或等于255,则使用1字节,否则使用2字节。以utf8字符集举例,即一个字符占用3个字节,N理论上能取到的值是(65535-2)/3=21844 。char(1)字符串对于单字节字符来说只会占用1个字节,但是varchar(1)会占用2个字节,其中1个字节用来存储长度信息。

     使用varchar(5)和varchar(100)保存‘abcde’占用的空间虽然都一样,但越大的
列会使用越多的内存,因为MySQL通常会分配固定大小的内存块来保存值。简单的
说,就是使用字符类型中定义的长度,即100个字符空间。所以如果你的MySQL内存
占用过高也有可能是因为返个原因,如基亍排序、使用基亍内存的临时表等等,磁盘
I/O也会激增。所以在使用varchar的时候一定要分配刚好就行。

     从碎片角度迕行考虑,使用CHAR字符型时,由亍存储空间都是一次性分配的。为此
某个字段的内容,其都是存储在一起的。单从返个角度来讲,其丌存在碎片的困扰。
而可变长度的字符数据类型,其存储的长度是可变的。当其更改前后数据长度丌一致
时,就丌可避免的会出现碎片的问题。故使用可变长度的字符型数据时,时丌时的对
碎片迕行整理。如执行数据库导出导入作业,来消除碎片。

2、怎么选择char 还是varchar

  char最佳的使用方案就是 存储很短的字符串戒者长度近似相同的字符串的时候非常有用。如固定长度的MD5、 定长值、短网址,存储用户的身份证号码、性别等等。其他的场景建议用varchar
  • 28
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 MySQL 中,CHARVARCHAR 是两种不同的数据类型,它们主要的区别在于存储方式和使用场景。 1. 存储方式 CHAR 类型是一种固定长度的字符串类型,它占用固定的存储空间,无论实际存储的字符串长度为多少,都会占用相同的存储空间。例如,如果定义了一个 CHAR(10) 的列,无论实际存储的字符串是 "hello" 还是 "world",都会占用 10 个字节的存储空间。 VARCHAR 类型是一种可变长度的字符串类型,它根据实际存储的字符串长度来动态分配存储空间。例如,如果定义了一个 VARCHAR(10) 的列,存储的字符串是 "hello",则只会占用 5 个字节的存储空间,而如果存储的字符串是 "world",则会占用 5 个字节的存储空间。 2. 使用场景 由于 CHAR 类型的固定长度特性,它更适合存储长度固定的字符串,例如存储电话号码、邮政编码等。而 VARCHAR 类型的可变长度特性,则更适合存储长度不固定的字符串,例如存储用户的姓名、地址等。 总体来说,CHAR 类型的存储效率比 VARCHAR 类型高,但在存储长度不固定的字符串时,VARCHAR 类型更为灵活。因此,在选择使用哪种类型时,需要根据具体的情况进行权衡。 ### 回答2: MySQLCHARVARCHAR是两种不同的数据类型,它们在存储和使用上有一些区别。 首先,CHAR是一种固定长度的字符串类型,它可以存储0到255个字符。当我们在定义一个CHAR类型的字段时,我们需要指定它的长度。无论我们存储的实际字符数是多少,CHAR类型的字段总是占用指定的长度。例如,如果我们定义一个CHAR(10)类型的字段,并存储一个只有3个字符的字符串,那么这个字段仍然会占用10个字符的空间,而剩下的7个字符会被填充为空格。 相比之下,VARCHAR是一种可变长度的字符串类型,它可以存储0到65535个字符。当我们定义一个VARCHAR类型的字段时,我们同样需要指定它的最大长度。不同于CHAR类型,VARCHAR类型的字段只占用实际存储的字符数加上一些额外的字节用来记录字符串的长度信息。所以当我们存储一个只有3个字符的字符串时,VARCHAR类型的字段仅仅会占用3个字符的空间。 由于CHAR类型在存储时需要额外的空间来填充空白字符,所以它在使用存储空间方面通常比VARCHAR类型更多。因此,在需要存储大量变长字符串的情况下,使用VARCHAR类型可以更有效地使用存储空间。 此外,由于CHAR类型总是占用固定的长度,所以对于查询和检索来说,CHAR类型的字段在处理上可能会更快一些。而VARCHAR类型由于长度可变,可能会稍微慢一些。 总结来说,CHARVARCHAR是两种不同的字符串类型,CHAR是固定长度的,VARCHAR是可变长度的。在选择使用哪种类型时,我们需要考虑存储空间的利用效率以及查询和检索的性能需求。 ### 回答3: MySQL中的CHARVARCHAR都是用于存储字符数据类型的字段。 区别如下: 1. 存储空间: - CHAR固定长度,使用指定的长度来存储数据,无论实际存储的数据长度是多少,都会占用指定长度的存储空间。如果存储的数据长度小于指定长度,会使用空格来填充剩余的空间。 - VARCHAR可变长度,根据实际存储的数据长度来分配存储空间,只占用实际数据的存储空间。不会填充额外的空格。 2. 存储效率: - CHAR在查询和存储固定长度的数据时,效率更高。由于数据长度固定,不需要额外计算存储空间的大小。 - VARCHAR在存储变长数据时,只占用实际数据的存储空间,对于存储较多变长数据的场景,可以节省存储空间。 3. 存储限制: - CHAR可以存储0-255个字符。 - VARCHAR可以存储0-65,535个字符。 4. 使用建议: - 对于存储固定长度的数据,如电话号码、国家代码等,可以使用CHAR类型。 - 对于存储长度不定的数据,如用户的姓名、地址等,可以使用VARCHAR类型。 综上所述,CHARVARCHAR的主要区别在于存储空间和存储效率,选择使用哪个类型要根据具体的需求和数据特点来决定。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值