0
点赞
收藏
分享

微信扫一扫

MySQL列的类型定义(三)

干自闭 2022-01-07 阅读 101

1、CHAR和VARCHAR

    CHAR类型和VARCHAR类型都在创建表时指定了最大长度,其基本形式如下:

    字符串类型(M)

    其中,“字符串类型”参数指定了数据类型为CHAR类型还是VARCHAR类型;M参数指定了该字符串的最大长度为M。例如,CHAR(4)就是数据类型为CHAR类型,其最大长度为4。

    CHAR类型的长度是固定的,在创建表时就指定了。其长度可以是0~255的任意值。例如,CHAR(100)就是指定CHAR类型的长度为100。CHAR 存储值时,它们会用空格右填充到指定的长度。

    VARCHAR类型的长度是可变的,在创建表时指定了最大长度。定义时,其最大值可以取0~65535之间的任意值。指定VARCHAR类型的最大值以后,其长度可以在0到最大长度之间。例如,VARCHAR(100)的最大长度是100,但是不是每条记录都要占用100个字节,而是在这个最大值范围内使用多少就分配多少。VARCHAR类型实际占用的空间为字符串的实际长度加1或2(存放这个自负床的长度),这样即可有效节约系统的空间。

create table char_example(e_char char(5), v_char varchar(5));
insert into char_example values('12345','12345'); 

      #char类型会屏蔽后面隐藏的空格,varchar 不会

 insert into char_example values('1 2  ','1 2  ');   

     这样看起来好像并没有什么差别,我们将select结果与“()”连接起来;(使用concat()函数);

select concat('(',e_char, ')'), concat('(',v_char, ')')  from char_example ; 

     varchar会根据输入字符串长度存储,而char则会将空格屏蔽掉(类似于C语言,varchar存储string.length,而char类似于字符数组只存储到'\0'符)


    当插入记录过长时则会报错

mysql>  insert into char_example values('12345','1234567');
ERROR 1406 (22001): Data too long for column 'v_char' at row 1

    但是有一种情况,当插入空格数多于指定长度时;

    这里空格+字符均有7个长度;

insert into char_example values('1 2   ','1 2   ');

 


2 、TEXT类型

    TEXT类型是一种特殊的字符串类型,包括TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT,其长度和存储空间的对比下表所示:

     各种TEXT类型的区别在于允许的长度和存储空间不同。因此,在这几种TEXT类型中,根据需求选取既能满足需要又节省空间的类型即可。 

特别注意

  1. 以上各类型无须指定长度!
  2. 允许的长度是指实际存储的字节数,而不是实际的字符个数,比如假设一个中文字符占两个字节, 那么TEXT 类型可存储 65535/2 = 32767  个中文字符,而varchar(100)可存储100个中文字符,实际占200个字节,但varchar(65535) 并不能存储65535个中文字符,因为已超出表达范围(varchar要预留1到2个字节存储这个字符的长度65535×2=131072,2字节整数最大只能到65535)。

    e_text最大长度为255字节,这里创建表的字符集为UTF-8,汉字占3个字节,所以可存储中文字符85个;v_char可存储100个中文字符,占300字节;

create table text_example(e_text tinytext, v_char varchar(100));
mysql> insert into text_example values('北国风光,千里冰封,万里雪飘。望长城内外,惟 余莽莽;大河上下,顿失滔,山舞银蛇 原驰蜡象,欲与天公试比高。须晴日,看红装素裹,分外妖娆。江山如此多娇,引无数英雄竞折腰。惜','北国风光,千里冰封,万里雪飘。望长城内外,惟余莽莽;大河上下,顿失滔,山舞银蛇,原驰蜡象,欲与天公试比高。须晴日,看红装素裹, 分外妖娆。江山如此多娇,引无数英雄竞折腰。惜秦皇汉武,略输文采;唐宗宋祖,');

    超出长度时则会报错。

举报

相关推荐

0 条评论