MySQL数据类型

Posted 予安

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL数据类型相关的知识,希望对你有一定的参考价值。

数值类型

整数类型字节最小值最大值
TINYINT1有符号 $-2^7$
无符号 0
有符号 $2^7-1$
无符号 $2^8-1$
SMALLINT2有符号 $-2^{15}$
无符号 0
有符号 $2^{15}-1$
无符号 $2^{16}-1$
MEDIUMINT3有符号 $-2^{23}$
无符号 0
有符号 $2^{23}-1$
无符号 $2^{24}-1$
INT、INTEGER4有符号 $-2^{31}$
无符号 0
有符号 $2^{31}-1$
无符号 $2^{32}-1$
BIGINT8有符号 $-2^{63}$
无符号 0
有符号 $2^{63}-1$
无符号 $2^{64}-1$
浮点数类型字节最小值最大值
FLOAT4$\\pm1.175494351E-38$$\\pm3.402823466E+38$
DOUBLE8$\\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 值,当该列为浮点类型时,会进行四舍五入,如果是定点数时,会将超出的丢掉。

日期时间类型

日期和时间类型字节最小值最大值
DATE41000-01-019999-12-31
DATETIME81000-01-01 00:00:009999-12-31 23:59:59
TIMESTAMP4197001010800012038年的某个时刻
TIME3-839:59:59839:59:59
YEAR119012155

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)MM 为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 数据时尾部空格会保留。
MySQL 其他内容可以参考MySQL目录

以上是关于MySQL数据类型的主要内容,如果未能解决你的问题,请参考以下文章

在代码片段中包含类型转换

对这个带有 & 不带 = 的代码片段返回类型感到非常困惑

从mysql的片段中加载ListView

硬核!管理mysql数据库的工具

对“xxx”类型的已垃圾回收委托进行了回调。这可能会导致应用程序崩溃损坏和数据丢失。向非托管代码传递委托时,托管应用程序必须让这些委托保持活动状态,直到确信不会再次调用它们。 错误解决一例。(代码片段

连接MySQL出现错误:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)(代码片段