一、int类型

包括TINYINT、SMALLINT、MEDIUMINT、INT、BIGINT几种类型。

数据类型

存储空间(字节)

取值范围

TINYINT

1

有符号(signed) : [-128, 127] 无符号(unsigned) :[0, 255]

SMALLINT

2

有符号(signed) : [-32768, 32767]无符号(unsigned) :[0, 65535]

MEDIUMINT

3

有符号(signed) : [-8388608, 8388607]无符号(unsigned) :[0, 16777215]

INT

4

有符号(signed) : [-2147483648, 2147483647]无符号(unsigned) :[0, 4294967295]

BIGINT

8

有符号(signed) : [-9223372036854775808, 9223372036854775807]无符号(unsigned) :[0, 18446744073709551615]

我们在设置数字类型时,根据业务场景选择合适的类型,以便于节约空间。需要注意的是,当设置为主键自增时,推荐用bigint类型作为主键,防止数字不够用的情况。

二、浮点类型

  • 单精度类型:FLOAT
    存储空间:4 字节
    精确性:低
  • 双精度类型:DOUBLE
    占用空间:8 字节
    精确性:低,比FLOAT高
  • 高精度类型:DECIMAL
    占用空间:变长
    精确性:非常高

三、字符串类型

mysql 设计数据字典表 mysql数据库字段类型详解_字段


几个存储大对象的字段,除了存储大小有区别外,其他的并无大的区别,使用时不用刻意区分。但是存储大对象,性能会下降,尽量避免存储大对象。

如果必须存储大对象,那么可以将其单独弄成一张表进行存储。

BLOB是最常用的大对象存储类型。这种类型只能指定索引前缀,而不能使用其他的普通索引。

varchar是可变长度的,就是规定了多长,如果用不了这么长,则不分配这么长的空间

char是固定长度的,分配了多长就多长。

所以大部分用varchar类型。对于长度固定的字段,可以直接申请为char类型,这样节约了mysql计算可变长度的时间,能一定程度上提升性能,虽然varchar是可变长度,但是mysql也会为其预留出来其规定的长度,所以varchar的数字也不是随便写的。

虽然varchar是可变长度的,但是长度也不能随便写,根据实际情况写各个字段的长度。

四、时间类型

mysql 设计数据字典表 mysql数据库字段类型详解_数据库_02


其中,datetime和timestamp表示范围不同,没有特殊业务,我们选择小的timestamp进行存储即可。

五、枚举类型

对于固定的值(非数字类型的),比如性别,省份等,可以设置成枚举类型,这样比varchar或char性能更高。数字类型的不要用枚举,而是用int。因为Mysql的枚举底层用的是数字存储,存数字的话,会造成混淆。

六、JSON类型

Mysql5.7以后的版本,支持json类型,自动校验数据格式,并提供函数处理,搜索json数据中的key,value等操作。