前言:

要理解一个数据库,咱们必须理解其反对的数据类型。MySQL 反对大量的字段类型,其中罕用的也有很多。后面文章咱们也讲过 int 及 varchar 类型的用法,但始终没有全面讲过字段类型,本篇文章咱们将把字段类型一网打尽,讲一讲常用字段类型的用法。

罕用的字段类型大抵能够分为数值类型字符串类型日期工夫类型三大类,上面咱们依照分类顺次来介绍下。

1.数值类型

数值类型大类又能够分为整型浮点型定点型三小类。

整型次要用于存储整数值,次要有以下几个字段类型:

整型常常被用到,比方 tinyint、int、bigint 。默认是有符号的,若只需存储无符号值,可减少 unsigned 属性。

int(M)中的 M 代表最大显示宽度,并不是说 int(1) 就不能存储数值10了,不论设定了显示宽度是多少个字符,int 都是占用4个字节,即int(5)和int(10)可存储的范畴一样。

存储字节越小,占用空间越小。所以本着最小化存储的准则,咱们要尽量抉择适合的整型,例如:存储一些状态值或人的年龄能够用 tinyint ;主键列,无正数,倡议应用 int unsigned 或者 bigint unsigned,预估字段数字取值会超过 42 亿,应用 bigint 类型。

浮点型次要有 float,double 两个,浮点型在数据库中寄存的是近似值,例如float(6,3),如果插入一个数123.45678,理论数据库里存的是123.457,但总个数还以理论为准,即6位,整数局部最大是3位。 float 和 double 平时用的不太多。

定点型字段类型有 DECIMAL 一个,次要用于存储有精度要求的小数。

DECIMAL 从 MySQL 5.1 引入,列的申明语法是 DECIMAL(M,D) 。 NUMERIC 与 DECIMAL 同义,如果字段类型定义为 NUMERIC ,则将主动转成 DECIMAL 。

对于申明语法 DECIMAL(M,D) ,自变量的值范畴如下:

  • M是最大位数(精度),范畴是1到65。可不指定,默认值是10。
  • D是小数点左边的位数(小数位)。范畴是0到30,并且不能大于M,可不指定,默认值是0。

例如字段 salary DECIMAL(5,2),可能存储具备五位数字和两位小数的任何值,因而能够存储在salary列中的值的范畴是从-999.99到999.99。

2.字符串类型

字符串类型也常常用到,罕用的几个类型如下表:

其中 char 和 varchar 是最罕用到的。char 类型是定长的,MySQL 总是依据定义的字符串长度调配足够的空间。当保留 char 值时,在它们的左边填充空格以达到指定的长度,当检索到 char 值时,尾部的空格被删除掉。varchar 类型用于存储可变长字符串,存储时,如果字符没有达到定义的位数,也不会在前面补空格。

char(M) 与 varchar(M) 中的的 M 示意保留的最大字符数,单个字母、数字、中文等都是占用一个字符。char 适宜存储很短的字符串,或者所有值都靠近同一个长度。例如,char 非常适合存储明码的 MD5 值,因为这是一个定长的值。对于字符串很长或者所要存储的字符串长短不一的状况,varchar 更加适合。

咱们在定义字段最大长度时应该按需分配,提前做好预估,能应用 varchar 类型就尽量不应用 text 类型。除非有存储长文本数据需要时,再思考应用 text 类型。

BLOB 类型次要用于存储二进制大对象,例如能够存储图片,音视频等文件。日常很少用到,有存储二进制字符串时能够思考应用。

3.日期工夫类型

MySQL反对的日期和工夫类型有 YEARTIMEDATEDATETIMETIMESTAMP,几种类型比拟如下:

波及到日期和工夫字段类型抉择时,依据存储需要抉择适合的类型即可。

对于 DATETIME 与 TIMESTAMP 两种类型如何选用,能够依照存储需要来,比方要求存储范畴更广,则举荐应用 DATETIME ,如果只是存储以后工夫戳,则能够应用 TIMESTAMP 类型。不过值得注意的是,TIMESTAMP 字段数据会随着零碎时区而扭转但 DATETIME 字段数据不会。总体来说 DATETIME 应用范畴更广。

总结:

本篇文章次要介绍了 MySQL 中罕用的字段类型,平时用到的字段类型根本都在这里了,以一张思维导图总结如下: