MySQL五种基础时间类型各具特点:DATE存日期(3字节,1000–9999年),DATETIME存完整时间且与时区无关(8字节,1000–9999年),TIMESTAMP存Unix时间戳、受时区影响且有2038年限制(4字节,1970–2038年),TIME存时间点或间隔(3字节,±838小时),YEAR存年份(1字节,1901–2155年)。

MySQL 中有五种基础时间类型:DATE、TIME、DATETIME、TIMESTAMP 和 YEAR。它们各自用途明确,存储方式和适用场景差异明显,选错类型可能影响精度、时区行为甚至未来扩容(比如 2038 年问题)。
DATE:只存日期,不带时间
格式为 YYYY-MM-DD,取值范围是 1000-01-01 到 9999-12-31,占用 3 字节。适合记录生日、入职日、合同生效日等无需具体时刻的场景。
- 插入 '2025-12-16' 或 '20251216' 都会被正确解析
- 不能存 '2025-02-30' 这类非法日期(除非开启
ALLOW_INVALID_DATES,但不推荐) - 零值是
0000-00-00,但参与计算(如DATE_ADD)时结果不可靠
DATETIME 与 TIMESTAMP:都能存完整时间,但本质不同
DATETIME 格式为 YYYY-MM-DD HH:MM:SS,范围大(1000–9999 年),占 8 字节,与时区无关,存什么显示什么。
TIMESTAMP 格式相同,但底层存的是 Unix 时间戳(从 1970-01-01 UTC 起的秒数),占 4 字节,自动受时区影响,范围窄(1970–2038),且默认支持自动初始化和更新(如 DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP)。
一、功能简介本软件完全适应大、中、小型网站建设需要,让您用很便宜的虚拟主机空间也可以开通4个独立的网站!久久企业网站后台管理系统各种版本开发基础架构均为php+mysql+div+css+伪静态,迎合搜索引擎排名的喜好。另外值得一提的是本站特色的TAG系统可为您的网站做出无限分类,不用任何设置全站ULR伪静态!本建站系统除了有产品发布、新闻(软文)发布、订单管理系统和留言反馈等一些最基本的功能之外
- 同一 TIMESTAMP 值在不同时区查询会显示不同时刻(例如 UTC+8 显示 10:00,UTC 下就是 02:00)
- DATETIME 不会自动更新,除非显式写触发器或应用层控制
- 若需长期存档(如金融历史数据)、跨时区一致性高,优先 DATETIME;若需轻量级自动记录创建/修改时间,且业务集中在单一或可控时区,TIMESTAMP 更省空间
TIME 和 YEAR:小而专的类型
TIME 存时间点或时间间隔,格式 HH:MM:SS,范围从 -838:59:59 到 838:59:59(注意可为负值,支持跨天计算),占 3 字节。常用于会议时段、工时统计、视频时长等。
YEAR 只存年份,占 1 字节,支持 4 位(1901–2155)或 2 位(00–69 → 2000–2069;70–99 → 1970–1999)。适合存毕业年份、车型年款等纯年维度数据。
- 插入
YEAR列时写 '69' 会被存为 2069,写 70 则是 1970 - TIME 支持类似 '-2 12:30:00' 表示“往前推 2 天 12 小时 30 分”,适合做时间差运算
怎么选?看三个关键点
不用死记硬背,抓住核心判断逻辑:
- 是否需要精确到秒级时间点?→ 否:用 DATE 或 YEAR;是:进入下一步
- 是否必须支持 2038 年以后的时间?→ 否:TIMESTAMP 可用;是:必须用 DATETIME
- 是否依赖自动更新或跨时区一致显示?→ 是自动更新/本地时区显示:TIMESTAMP;是跨时区统一解读:DATETIME









