Char 和Varchar 很相似,但是储存和提取的方式却是不同的。同时,他们的最大长度和是否保存跟随空格也是不同的。
Char 和Varchar 声明了你想储存的字符的最大长度。例如,Char(30) 最大可以保存30个字符。
在你创建一个表的时候,Char所声明的那一列变量的长度是固定的,数值可以定在0到255之间。当Char的变量输入时,如果变量长度没有达到你所声明的长度,则用空格在后方补全直到长度到达你所声明的长度。在提取变量的时候,空格将会被自动去除,当然,在 “Pad Char To Full Length SQL” 模式下是不去除的。
Varchar 所声明的那一列变量的长度是可变化的,数值可以定在0到65,535之间。Varchar 的最大长度受制于行的大小和其所设的字符大小,详情见 “Limits on Table Column Count and Row Size” 。
与Char 对比,Varchar 以1字节或2字节的前缀长度保存。这个前缀长度指明了该值的字节数。如果一列值的大小没有超过255字节,那么该列只需要一个字节长度;如果超过255,则需要两个字节长度。
如果 strict SQL 模式没有打开,并且你所赋的值超过了Char 和Varchar 的最大值,那么为了符合要求,该值就会被裁切,进而可能导致错误发生。而在strict SQL 模式下则会禁止你输入该值,见 “Server SQL Modes” 。
对于Varchar 列来说,无论SQL mode 是否使用,剪断多出的尾随空格都要优先于插入,并且会生成一个Warning。对于Char 列来说,无论SQL mode 是否使用,都会静默剪断插入值多出的尾随空格。
Varchar 值在储存时不会被填补空格,即没达到所声明的长度时不会像Char 在后面填补空格强行达到声明长度。Varchar 值所包含的空格在保存和提取的时候都会被保留下来,与标准SQL保持一致。
下表展示了Char 和Varchar 在储存方式上的不同:
Value | Char(4) | 所需储存空间 | Varchar(4) | 所需储存 |
---|---|---|---|---|
” | ’ ‘ | 4 bytes | ” | 1 byte |
‘ab’ | ‘ab ‘ | 4 bytes | ‘ab’ | 3 bytes |
‘abcd’ | ‘abcd’ | 4 bytes | ‘abcd’ | 5 bytes |
‘abcdefgh’ | ‘abcd’ | 4 bytes | ‘abcd’ | 5 bytes |
本文译自MySQL官方教程,原文请参照:https://dev.mysql.com/doc/refman/5.7/en/char.html