MySQL中日期和时间戳的转换:字符到DATE和TIMESTAMP的相互转换

在MySQL中,经常需要在 DATETIMESTAMP 和字符串之间进行相互转换。以下是一些常见的转换方法:

1. 字符串到日期/时间类型
  • 字符串转 DATE:

    使用 STR_TO_DATE() 函数将字符串转换为 DATE 类型。你需要提供字符串的格式。

    复制代码
    SELECT STR_TO_DATE('2024-08-24', '%Y-%m-%d') AS my_date;
  • 字符串转 TIMESTAMP:

    同样使用 STR_TO_DATE() 函数,但格式要包括时间部分。

    复制代码
    SELECT STR_TO_DATE('2024-08-24 14:35:00', '%Y-%m-%d %H:%i:%s') AS my_timestamp;
2. 日期/时间类型到字符串
  • DATE 转字符串:

    使用 DATE_FORMAT() 函数将 DATE 转换为指定格式的字符串。

    复制代码
    SELECT DATE_FORMAT(NOW(), '%Y-%m-%d') AS date_str;
  • TIMESTAMP 转字符串:

    使用 DATE_FORMAT() 函数将 TIMESTAMP 转换为指定格式的字符串。

    复制代码
    SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s') AS timestamp_str;
3. 日期类型和时间戳类型之间的转换
  • DATETIMESTAMP:

    DATE 类型只有日期部分,没有时间部分,MySQL 在转换时会默认将时间部分设置为 00:00:00

    复制代码
    SELECT CAST('2024-08-24' AS DATETIME) AS date_to_timestamp;
  • TIMESTAMPDATE:

    使用 DATE() 函数从 TIMESTAMP 中提取日期部分。

    复制代码
    SELECT DATE(NOW()) AS timestamp_to_date;
4. UNIX_TIMESTAMPDATE/TIMESTAMP 的相互转换
  • UNIX_TIMESTAMPTIMESTAMP:

    使用 FROM_UNIXTIME() 函数将 UNIX_TIMESTAMP 转换为 TIMESTAMP

    复制代码
    -- 将UNIX时间戳转为时间戳
    SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()) AS unix_to_timestamp;
    -- UNIX时间戳转时间戳 (如果是13位需要除1000)
    SELECT FROM_UNIXTIME(1692874200) AS unix_to_timestamp;
  • TIMESTAMPUNIX_TIMESTAMP:

  • 使用 UNIX_TIMESTAMP() 函数将 TIMESTAMP 转换为 UNIX_TIMESTAMP

    复制代码
    -- 将时间戳转换为UNIX时间戳
    SELECT UNIX_TIMESTAMP(NOW()) AS timestamp_to_unix;
5. 直接通过类型转换函数
  • CAST 和 CONVERT 函数:

    使用 CAST()CONVERT() 函数可以在 DATETIMESTAMP 和字符串之间进行转换。

    复制代码
    SELECT CAST('2024-08-24 14:35:00' AS DATE) AS cast_to_date;
    
    SELECT CONVERT(NOW(), CHAR) AS convert_to_string;
6. 字符串到日期或时间戳,带时区的转换
  • CONVERT_TZ: 将时间戳从一个时区转换到另一个时区。

    -- 将UTC时间戳转换为东八区时间

    SELECT CONVERT_TZ('2024-08-24 06:00:00', '+00:00', '+08:00');

7. 字符串直接转换为时间戳
  • 如果字符串格式与时间戳的默认格式一致,可以直接进行转换,这会自动将字符串转换为时间戳。注意这种方法仅适用于字符串格式精确匹配默认的DATETIME格式。

    SELECT '2024-08-24 14:30:00' + 0 AS timestamp_value;

常用的格式化符号:
  • %Y 年(四位)
  • %m 月(两位)
  • %d 日(两位)
  • %H 小时(24小时制)
  • %i 分钟
  • %s
相关推荐
ZC跨境爬虫2 小时前
跟着 MDN 学CSS day_6:(伪类和伪元素详解)
前端·javascript·css·数据库·ui·html
洛水水2 小时前
Redis对象类型与底层数据结构
数据结构·数据库·redis
倔强的石头_3 小时前
深度解析:数据库内核如何通过逻辑推理与常值推导突破去重性能瓶颈
数据库
devilnumber3 小时前
MySQL 部门表:树结构 (自关联) vs 非树结构 (扁平化 / 冗余字段)
数据库·mysql
User_芊芊君子3 小时前
一条命令搞定 mysql_exporter 部署,Shell 脚本把重复配置这件事自动化了
android·mysql·自动化
fengxin_rou3 小时前
【MySQL 三大日志深度解析】:redo log、undo log、binlog 作用与两阶段提交原理
数据库·mysql·日志·redo log
ECT-OS-JiuHuaShan3 小时前
存在是微分张量积,标量是参数但不可能是本质。还原论泛化,是语义劫持和以偏概全的逻辑谋杀伪科学庞氏骗局
数据库·人工智能·算法·机器学习·数学建模
IT策士3 小时前
Django 从 0 到 1 打造完整电商平台:使用 Django 消息框架与用户权限初步
数据库·django·sqlite
星河耀银海3 小时前
JAVA 注解(Annotation):从原理到实战应用
java·开发语言·数据库
lzp07913 小时前
基于多模态视觉模型和图文向量模型的工业图像知识库研究与应用(伍)
数据库·学习·neo4j