MySQL数据类型

在本教程中,您将了解MySQL数据类型以及如何在MySQL中设计数据库时有效地使用它们。

数据库表包含具有特定数据类型(如数字或字符串)的多个列。 MySQL提供更多的数据类型,而不仅仅是数字或字符串。 MySQL中的每种数据类型都可以通过以下特征来确定:

  • 它用来表示数据值。
  • 占用的空间以及值是固定长度还是可变长度。
  • 数据类型的值可以被索引。
  • MySQL如何比较特定数据类型的值。
数据类型指定值和范围
charString(0~255)
varcharString(0~255)
tinytextString(0~255)
textString(0~65536)
blobString(0~65536)
mediumtextString(0~16777215)
mediumblobString(0~16777215)
longblobString(0~4294967295)
longtextString(0~4294967295)
tinyintInteger(-128~127)
smallintInteger(-32768~32767)
mediumintInteger(-8388608~8388607)
intInteger(-214847668~214847667)
bigintInteger(-9223372036854775808~9223372036854775807)
floatdecimal(精确到23位小数)
doubledecimal(24~54位小数)
decimaldouble转储为字符串形式
dateYYYY-MM-DD
datetimeYYYY-MM-DD HH:MM:SS
timestampYYYYMMDDHHMMSS
timeHH:MM:SS
enum选项值之一
set选项值子集
booleantinyint(1)

MySQL数值数据类型

在MySQL中,您可以找到所有SQL标准数字类型,包括精确数字数据类型和近似数字数据类型,包括整数,定点和浮点数。 此外,MySQL还具有用于存储位值的BIT数据类型。数字类型可以是有符号或无符号,但BIT类型除外。

下表显示了MySQL中数字类型的总结:

数字类型描述
TINYINT一个很小的整数
SMALLINT一个小的整数
MEDIUMINT一个中等大小的整数
INT一个标准整数
BIGINT一个大整数
DECIMAL定点数
FLOAT单精度浮点数
DOUBLE双精度浮点数
BIT一个字节字段

MySQL布尔数据类型

MySQL没有内置的 BOOLEAN 或 BOOL 数据类型。所以要表示布尔值,MySQL使用最小的整数类型,也就是TINYINT(1)。 换句话说,BOOLEANBOOLTINYINT(1)的同义词。

MySQL字符串数据类型

在MySQL中,字符串可以容纳从纯文本到二进制数据(如图像或文件)的任何内容。可以通过使用LIKE运算符,正则表达式和全文搜索,根据模式匹配来比较和搜索字符串。

下表显示了MySQL中的字符串数据类型:

字符串类型描述
char固定长度的非二进制(字符)字符串
varchar可变长度的非二进制字符串
BINARY一个固定长度的二进制字符串
VARBINARY一个可变长度的二进制字符串
TINYBLOB一个非常小的BLOB(二进制大对象)
BLOB一个小的BLOB(二进制大对象)
MEDIUMBLOB一个中等大小的BLOB(二进制大对象)
LONGBLOB一个大的BLOB(二进制大对象)
TINYTEXT一个非常小的非二进制字符串
TEXT一个小的非二进制字符串
MEDIUMTEXT一个中等大小的非二进制字符串
LONGTEXT一个很大的非二进制字符串
ENUM枚举; 每个列值可以被分配一个枚举成员
SET集合; 每个列值可以分配零个或多个SET成员

MySQL日期和时间数据类型

MySQL提供日期和时间的类型以及日期和时间的组合。 此外,MySQL还支持时间戳数据类型,用于跟踪表的一行中的更改。如果只想存储没有日期和月份的年份数据,则可以使用YEAR数据类型。

下表说明了MySQL日期和时间数据类型:

字符串类型描述
DATEYYYY-MM-DD格式的日期值
TIMEhh:mm:ss格式的时间值
DATETIMEYYYY-MM-DD hh:mm:ss格式的日期和时间值
TIMESTAMPYYYY-MM-DD hh:mm:ss格式的时间戳记值
YEARYYYYYY格式的年值

MySQL空间数据类型

MySQL支持许多包含各种几何和地理值的空间数据类型,如下表所示:

字符串类型描述
GEOMETRY任何类型的空间值
POINT一个点(一对X-Y坐标)
LINESTRING曲线(一个或多个POINT值)
POLYGON多边形
GEOMETRYCOLLECTIONGEOMETRY值的集合
MULTILINESTRINGLINESTRING值的集合
MULTIPOINTPOINT值的集合
MULTIPOLYGONPOLYGON值的集合

JSON数据类型

MySQL 5.7.8版本支持原生JSON数据类型,可以更有效地存储和管理JSON文档。 本机JSON数据类型提供JSON文档的自动验证和最佳存储格式。

在本教程中,您学习了各种MySQL数据类型,可帮助您确定在创建表时应使用哪些数据类型。

    点赞