在创建数据库表时,例如
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个成员)