在创建数据库表时,例如
create table user
(
id int(4) primary key ,
name varchar(20),
pwd varchar(20)
);
括号里的数字叫数据的宽度,我们不能一概而论,因为不同的数据类型对宽度的处理也不一样:
1、整数类型,这里显示的宽度和数据类型的取值范围是没有任何关系的,显示宽度只是指明Mysql最大可能显示的数字个数,数值的位数小于指定的宽度时会由空格填充;如果插入了大于显示宽度的值,只要该值不超过该类型的取值范围,数值依然可以插入,而且能够显示出来。
例如上面的udi,显示的宽度是4,但是我向uid中插入100001,也是可以的,保存和显示的都会是100001
如果你不设置宽度,系统将添加默认的宽度 tinyint(4),smallint(6),mediumint(9),int(11),bigint(20),这些默认的宽度是跟该类型的取值范围长度相关。
2、字符串类型,字符串类型这个宽度才真的用上了。不管是char还是varchar,宽度都定义了字符串的最大长度
例如上面的 password varchar(20),如果你输入了一个21个字符的密码,那么保存和显示的只会是前20个字符,你将丢失一个字符信息,char同理。由于varchar是变长存储的,所以实际开发中我们一般都把varchar的宽度设为最长255,反正你没用完它也不会浪费空间。
3、浮点和日期等数据类型对数据的宽度没有要求,一般也不设置,默认是0
序号 | 列类型 | 需要的存储量 |
1 | TINYINT | 1字节 |
2 | SMALLINT | 2个字节 |
3 | MEDIUMINT | 3个字节 |
4 | INT | 4个字节 |
5 | INTEGER | 4个字节 |
6 | BIGINT | 8个字节 |
7 | FLOAT(X) | 4如果 X < = 24或 8如果 25 < = X < = 53 |
8 | FLOAT | 4个字节 |
9 | DOUBLE | 8个字节 |
11 | DOUBLE PRECISION | 8个字节 |
12 | REAL | 8个字节 |
13 | DECIMAL(M,D) | M字节(D+2 ,如果M < D) |
14 | NUMERIC(M,D) | M字节(D+2 ,如果M < D) |
日期和时间类型
序号 | 列类型 | 需要的存储量 |
1 | DATE | 3个字节 |
2 | DATETIME | 8个字节 |
3 | TIMESTAMP | 4个字节 |
4 | TIME | 3个字节 |
5 | YEAR | 1字节 |
串类型
序号 | 列类型 | 需要的存储量 |
1 | CHAR(M) | M字节,1 <= M <= 255 |
2 | VARCHAR(M) | L+1字节,在此L <= M和1 <= M <= 255 |
3 | TINYBLOB,TINYTEXT | L+1字节,在此L< 2 ^ 8 |
4 | BLOB, TEXT | L+2字节,在此L< 2 ^ 16 |
5 | MEDIUMBLOB, MEDIUMTEXT | L+3字节,在此L< 2 ^ 24 |
6 | LONGBLOB, LONGTEXT | L+4字节,在此L< 2 ^ 32 |
7 | ENUM('value1','value2',...) | 1或 2个字节,取决于枚举值的数目(最大值65535) |
8 | SET('value1','value2',...) | 1,2,3,4或8个字节,取决于集合成员的数量(最多64个成员) |