MySQL支持的数据类型有哪些?

来源:IPIPP.com作者:头衔:全栈工程师
导读:本期聚焦于小伙伴创作的《MySQL支持的数据类型有哪些?》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《MySQL支持的数据类型有哪些?》有用,将其分享出去将是对创作者最好的鼓励。

MySQL作为常用的关系型数据库,提供了丰富的数据类型来适配不同的业务存储需求,合理选择数据类型能减少存储占用、提升查询效率。下面我们逐一介绍MySQL支持的主要数据类型。

MySQL支持的数据类型有哪些?

一、数值类型

数值类型用于存储整数、小数等数值数据,分为整数类型和浮点数/定点数类型两类。

1. 整数类型

整数类型按存储范围和字节数不同分为以下几类,可根据数值范围选择对应类型:

类型名称字节数有符号范围无符号范围
TINYINT1-128 ~ 1270 ~ 255
SMALLINT2-32768 ~ 327670 ~ 65535
MEDIUMINT3-8388608 ~ 83886070 ~ 16777215
INT/INTEGER4-2147483648 ~ 21474836470 ~ 4294967295
BIGINT8-9223372036854775808 ~ 92233720368547758070 ~ 18446744073709551615

使用时可以通过UNSIGNED关键字声明无符号类型,比如TINYINT UNSIGNED就表示0到255的范围。

2. 浮点数与定点数类型

浮点数类型用于存储近似值,定点数类型用于存储精确值,适合金额等需要高精度的场景:

  • FLOAT(M,D):单精度浮点数,4字节,M是总位数,D是小数位数
  • DOUBLE(M,D):双精度浮点数,8字节,精度比FLOAT更高
  • DECIMAL(M,D):定点数,存储精确的小数值,M默认10,D默认0,适合金额存储

二、字符串类型

字符串类型用于存储文本、二进制数据等内容,不同类型适配不同的存储场景。

1. 文本字符串类型

  • CHAR(N):定长字符串,N表示字符长度,最大255,存储时会用空格填充到指定长度,查询时去掉尾部空格
  • VARCHAR(N):变长字符串,N表示最大字符长度,存储时只占用实际长度加1-2字节的长度标识,更节省空间
  • TINYTEXT:最大存储255字符
  • TEXT:最大存储65535字符
  • MEDIUMTEXT:最大存储16777215字符
  • LONGTEXT:最大存储4294967295字符

2. 二进制字符串类型

用于存储二进制数据,比如图片、文件内容的二进制流:

  • BINARY(N):定长二进制字符串,类似CHAR但存储二进制数据
  • VARBINARY(N):变长二进制字符串,类似VARCHAR但存储二进制数据
  • TINYBLOBBLOBMEDIUMBLOBLONGBLOB:对应不同大小的二进制大对象,存储二进制数据

3. 枚举和集合类型

  • ENUM('值1','值2',...):枚举类型,只能从预设的列表中选一个值存储,最多65535个枚举值
  • SET('值1','值2',...):集合类型,可以从预设的列表中选多个值存储,最多64个集合值

三、日期和时间类型

用于存储日期、时间相关的数据,不同类型覆盖不同的时间精度:

  • DATE:存储日期,格式YYYY-MM-DD,范围1000-01-01到9999-12-31
  • TIME:存储时间,格式HH:MM:SS,范围-838:59:59到838:59:59
  • DATETIME:存储日期+时间,格式YYYY-MM-DD HH:MM:SS,范围1000-01-01 00:00:00到9999-12-31 23:59:59
  • TIMESTAMP:时间戳,存储从1970-01-01 00:00:00到9999-12-31 23:59:59的时间,会自动更新为当前时间(可配置)
  • YEAR:存储年份,格式YYYY,范围1901到2155

四、其他特殊类型

除了上述常用类型,MySQL还有一些特殊用途的数据类型:

  • BOOLEAN/BOOL:实际上是TINYINT(1)的别名,0表示假,非0表示真
  • JSON:MySQL 5.7.8之后支持的原生JSON类型,可直接存储JSON格式数据,支持JSON函数操作

五、数据类型选择示例

下面通过一个建表语句展示不同数据类型的实际使用:

-- 创建用户表,展示不同数据类型的用法
CREATE TABLE user_info (
  id INT UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用户ID',
  username VARCHAR(50) NOT NULL COMMENT '用户名',
  age TINYINT UNSIGNED COMMENT '年龄',
  balance DECIMAL(10,2) NOT NULL DEFAULT 0.00 COMMENT '账户余额',
  gender ENUM('男','女','未知') NOT NULL DEFAULT '未知' COMMENT '性别',
  register_time DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间',
  profile JSON COMMENT '用户扩展信息',
  PRIMARY KEY (id)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

在实际开发中,建议根据数据的实际范围、精度要求和查询频率选择最合适的数据类型,避免过度设计导致存储浪费。

MySQL数据类型数值类型字符串类型日期时间类型修改时间:2026-05-25 00:28:37

免责声明:已尽一切努力确保本网站所含信息的准确性。网站部分内容来源于网络或由用户自行发表,内容观点不代表本站立场。本站是个人网站免费分享,内容仅供个人学习、研究或参考使用,如内容中引用了第三方作品,其版权归原作者所有。若内容触犯了您的权益,请联系我们进行处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。前端、网络、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握网站开发与运维所需的核心技术栈。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端逻辑,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。