乐趣区

关于数据库:MySQL-数据类型

数值类型

整数类型 字节 最小值 最大值
TINYINT 1 有符号 $-2^7$
无符号 0
有符号 $2^7-1$
无符号 $2^8-1$
SMALLINT 2 有符号 $-2^{15}$
无符号 0
有符号 $2^{15}-1$
无符号 $2^{16}-1$
MEDIUMINT 3 有符号 $-2^{23}$
无符号 0
有符号 $2^{23}-1$
无符号 $2^{24}-1$
INT、INTEGER 4 有符号 $-2^{31}$
无符号 0
有符号 $2^{31}-1$
无符号 $2^{32}-1$
BIGINT 8 有符号 $-2^{63}$
无符号 0
有符号 $2^{63}-1$
无符号 $2^{64}-1$
浮点数类型 字节 最小值 最大值
FLOAT 4 $\pm1.175494351E-38$ $\pm3.402823466E+38$
DOUBLE 8 $\pm2.2250738585072014E-308$ $\pm1.7976931348623157E+308$
定点数类型 字节 形容
DEC(M,D),
DECIMAL(M,D)
M+2 最大取值范畴与 DOUBLE 雷同,给定 DECIMAL 的无效取值范畴由 M 和 D 决定

整数类型

在整数类型中,依照取值范畴和存储形式不同,分为 tinyint、smallint、mediumint、int 和 bigint 这 5 个类型。如果超出类型范畴的操作,会产生“Out of range”谬误提醒

对于整型数据,MySQL 还反对在类型名称前面的小括号内指定 显示宽度 ,例如int(5) 示意当数值宽度小于 5 位的时候在数字后面填满宽度,如果不显式指定宽度则默认为 int(11)。如果配合 zerofil 应用时,数字位数不够的空间用字符 0 填满。

设置宽度后,如果插入大于宽度限度的值,不会对插入的数据有任何影响,还是依照类型的理论精度进行保留,这时,宽度格局理论曾经没有意义。

很多的整数类型都有一个可选属性 UNSIGNED(无符号),如果须要在字段外面保留非正数或者须要较大的上限值时,能够用此选项,它的取值范畴是正常值的上限取 0,下限取原值的 2 倍。如果一个列指定为 zerofill,则 MySQL 主动为该列增加 UNSIGNED 属性。

另外,整数类型还有一个属性:AUTO_INCREMENT。在须要产生惟一标识符或程序值时,可利用此属性,这个属性只用于整数类型。值个别从 1 开始,每行减少 1。一个表中最多只能有一个 AUTO_INCREMENT 列。对于任何想要应用 AUTO_INCREMENT 的列,应该定义为 NOT NULL,并定义为 PRIMARY KEY 或者定义为 UNIQUE 键。

小数类型

小数类型分为两种:浮点数 定点数

浮点数包含 float(单精度)和 double(双精度),而定点数则只有 decimal 一种示意。

定点数在 MySQL 外部以字符串模式寄存,比浮点数更准确,适宜用来示意货币等精度高的数据

浮点数和定点数都能够用类型名称后加(M,D)的形式来进行示意,示意该值一共 M 位数字(整数位 + 小数位),其实 D 示意小数位的长度,M 和 D 又称为精度和标度。在不指定精度时,默认会依照理论的精度(由理论的硬件和操作系统决定)来显示,而 decimal 在不指定精度时,默认的整数位为 10,默认的小数位为 0。须要留神的是,浮点数前面跟(M,D)的用法是非规范用法,如果要用于数据库的迁徙,则最好不要这么应用。

MySQL 在保留值时,如果小数位长度超过 D 值,当该列为浮点类型时,会进行四舍五入,如果是定点数时,会将超出的丢掉。

日期工夫类型

日期和工夫类型 字节 最小值 最大值
DATE 4 1000-01-01 9999-12-31
DATETIME 8 1000-01-01 00:00:00 9999-12-31 23:59:59
TIMESTAMP 4 19700101080001 2038 年的某个时刻
TIME 3 -839:59:59 839:59:59
YEAR 1 1901 2155

TIMESTAMP 和 DATETIME 的区别:

  • TIMESTAMP 反对的工夫范畴较小,其取值范畴从 19700101080001 到 2038 年的某个工夫,因而不适宜寄存比拟长远的日期,而 DATETIME 是从 1000-01-01 00:00:00 到 9999-12-31 23:59:59,范畴更大。
  • 表中的第一个 TIMESTAMP 列主动设置为零碎工夫。当插入的值超出取值范畴时,MySQL 认为该值溢出,应用 0000-00-00 00:00:00 进行填补。
  • TIMESTAMP 的插入和查问都受到当地时区的影响,更能反映出理论的日期。DATETIME 只能反映出插入时当地的时区,其它时区的人查看数据必然会有误差的。

字符串类型

字符串类型 字节 形容及存储需要
CHAR(M) M M 为 0~255 之间的整数
VARCHAR(M) M 为 0~65535 之间的整数,值的长度 + 1 个字节
TINYBLOB 容许长度 0~255 字节,值的长度 + 1 个字节
BLOB 容许长度 0~65535 字节,值的长度 + 2 个字节
MEDIUMBLOB 容许长度 0~167772150 字节,值的长度 + 3 个字节
LONGBLOB 容许长度 0~4294967295 字节,值的长度 + 4 个字节
TINYTEXT 容许长度 0~255 字节,值的长度 + 2 个字节
TEXT 容许长度 0~65525 字节,值的长度 + 2 个字节
MEDIUMTEXT 容许长度 0~167772159 字节,值的长度 + 3 个字节
LONGTEXT 容许长度 0~4294967295 字节,值的长度 + 4 个字节
VARBINARY(M) 容许长度 0~M 个字节的变长字节字符串,值的长度 + 1 个字节
BINARY(M) M 容许长度 0~M 个字节的定长字节字符串

CHAR 和 VARCHAR 类型

  • CHAR 列的长度固定为创立表时申明的长度,长度能够为从 0~255 的任何值,存储时,如果字符数没有达到定义的位数,会在前面用空格补全入数据库中;VARCHAR 列中的值可变长字符串,如果没有达到定义的位数,也不会在前面补空格。
  • 在获取数据时,CHAR 列会把前面的空格全副抛弃掉;取 VARCHAR 数据时尾部空格会保留。
退出移动版