mysql字段每个类型长度大小与建表的类型长度

来源:互联网 发布:windows10 linux子系统 编辑:程序博客网 时间:2024/06/16 13:57

在创建数据库表时,例如

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 <= M1 <= 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',...)

12348个字节,取决于集合成员的数量(最多64个成员)