乐趣区

关于mysql:MySQL字段类型最全解析

前言:

要理解一个数据库,咱们必须理解其反对的数据类型。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 中罕用的字段类型,平时用到的字段类型根本都在这里了,以一张思维导图总结如下:

退出移动版