1 文本字符串类型
CHAR与VARCHAR类型
字符串(文本)类型 |
特点 |
长度 |
长度范围 |
占用的存储空间 |
CHAR(M) |
固定长度 |
M |
0 <= M <= 255 |
M个字节 |
VARCHAR(M) |
可变长度 |
M |
0 <= M <= 65535 |
(实际长度 + 1) 个字节 |
CHAR类型
CHAR(M) 类型一般需要预先定义字符串长度。如果不指定(M),则表示长度默认是1个字符。
如果保存时,数据的实际长度比CHAR类型声明的长度小,则会在右侧填充空格以达到指定的长度。当MySQL检索CHAR类型的数据时,CHAR类型的字段会去除尾部的空格。
定义CHAR类型字段时,声明的字段长度即为CHAR类型字段所占的存储空间的字节数。
CREATE TABLE test_char1(
c1 CHAR,-- 存1个字符
c2 CHAR(5) -- 存5个字符
);
INSERT INTO test_char1(c1) VALUES('a');
SELECT * FROM test_char1;
+------+------+
| c1 | c2 |
+------+------+
| a | NULL |
+------+------+
INSERT INTO test_char1(c1) VALUES('ab');-- 字符太长, mysql控制台插不进去,sqlyog插入前1个字符a
SELECT * FROM test_char1;
+------+------+
| c1 | c2 |
+------+------+
| a | NULL |
| a | NULL |
+------+------+
INSERT INTO test_char1(c2)
VALUES ('ab');
INSERT INTO test_char1(c2)
VALUES ('hello');
INSERT INTO test_char1(c2)
VALUES ('尚');
INSERT INTO test_char1(c2)
VALUES ('硅谷'); -- 插入成功 存'尚硅谷'底层就是用了5个字符 体现固定长度
+------+-------+
| c1 | c2 |
+------+-------+
.....
| NULL | ab |
| NULL | hello |
| NULL | 尚 |
| NULL | 硅谷 |
+------+-------+
INSERT INTO test_char1(c2)
VALUES ('尚硅谷IT教育');-- 字符太长, mysql控制台插不进去,sqlyog插入前5个字符
+------+----------+
| c1 | c2 |
+------+----------+
...
| NULL | 尚硅谷IT |
+------+----------+
INSERT INTO test_char1(c2) VALUES ('ab ')-- 四个字符
SELECT CHAR_LENGTH (c2) FROM test_char1;
+------------------+
| CHAR_LENGTH (c2) |
+------------------+
...
| 2 | -- 插入的'ab '明明是4个字符,但因为MySQL检索CHAR类型的数据时,CHAR类型的字 段会去除尾部的空格,所以是2
+------------------+
VARCHAR类型
VARCHAR(M) 定义时,必须指定长度M,否则报错。
MySQL4.0版本以下,varchar(20):指的是20字节,如果存放UTF8汉字时,只能存6个(每个汉字3字节) ;MySQL5.0版本以上,varchar(20):指的是20字符。 varchar最大字节数没有变,M变了
#Column length too big for column 'NAME' (max = 21845);
CREATE TABLE test_varchar2(
NAME VARCHAR(65535) #错误
);
CREATE TABLE test_varchar3(
NAME VARCHAR(5)
);
INSERT INTO test_varchar3
VALUES('尚硅谷'),('尚硅谷教育');-- 插入成功 存'尚硅谷'底层就是用了3个字符 体现可变长度
#Data too long for column 'NAME' at row 1 mysql控制台插不进去,sqlyog插入前5个字符尚硅谷IT
INSERT INTO test_varchar3
VALUES('尚硅谷IT教育');
检索VARCHAR类型的字段数据时,会保留数据尾部的空格。VARCHAR类型的字段所占用的存储空间为字符串实际长度加1个字节。
CHAR 、VARCHAR 适用场景
类型 |
特点 |