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

打印 上一主题 下一主题

主题 855|帖子 855|积分 2565

在MySQL中,经常需要在 DATE、TIMESTAMP 和字符串之间进行相互转换。以下是一些常见的转换方法:
1. 字符串到日期/时间类型



  • 字符串转 DATE:
    使用 STR_TO_DATE() 函数将字符串转换为 DATE 类型。你需要提供字符串的格式。
    1. SELECT STR_TO_DATE('2024-08-24', '%Y-%m-%d') AS my_date;
    复制代码
  • 字符串转 TIMESTAMP:
    同样使用 STR_TO_DATE() 函数,但格式要包括时间部分。
    1. SELECT STR_TO_DATE('2024-08-24 14:35:00', '%Y-%m-%d %H:%i:%s') AS my_timestamp;
    复制代码
2. 日期/时间类型到字符串



  • DATE 转字符串:
    使用 DATE_FORMAT() 函数将 DATE 转换为指定格式的字符串。
    1. SELECT DATE_FORMAT(NOW(), '%Y-%m-%d') AS date_str;
    复制代码
  • TIMESTAMP 转字符串:
    使用 DATE_FORMAT() 函数将 TIMESTAMP 转换为指定格式的字符串。
    1. SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s') AS timestamp_str;
    复制代码
3. 日期类型和时间戳类型之间的转换



  • DATE 转 TIMESTAMP:
    DATE 类型只有日期部分,没有时间部分,MySQL 在转换时会默认将时间部分设置为 00:00:00。
    1. SELECT CAST('2024-08-24' AS DATETIME) AS date_to_timestamp;
    复制代码
  • TIMESTAMP 转 DATE:
    使用 DATE() 函数从 TIMESTAMP 中提取日期部分。
    1. SELECT DATE(NOW()) AS timestamp_to_date;
    复制代码
4. UNIX_TIMESTAMP 和 DATE/TIMESTAMP 的相互转换



  • UNIX_TIMESTAMP 转 TIMESTAMP:
    使用 FROM_UNIXTIME() 函数将 UNIX_TIMESTAMP 转换为 TIMESTAMP。
    1. -- 将UNIX时间戳转为时间戳
    2. SELECT FROM_UNIXTIME(UNIX_TIMESTAMP()) AS unix_to_timestamp;
    3. -- UNIX时间戳转时间戳 (如果是13位需要除1000)
    4. SELECT FROM_UNIXTIME(1692874200) AS unix_to_timestamp;
    复制代码
  • TIMESTAMP 转 UNIX_TIMESTAMP:
  • 使用 UNIX_TIMESTAMP() 函数将 TIMESTAMP 转换为 UNIX_TIMESTAMP。
    1. -- 将时间戳转换为UNIX时间戳
    2. SELECT UNIX_TIMESTAMP(NOW()) AS timestamp_to_unix;
    复制代码
5. 直接通过类型转换函数



  • CAST 和 CONVERT 函数:
    使用 CAST() 或 CONVERT() 函数可以在 DATE、TIMESTAMP 和字符串之间进行转换。
    1. SELECT CAST('2024-08-24 14:35:00' AS DATE) AS cast_to_date;
    2. SELECT CONVERT(NOW(), CHAR) AS convert_to_string;
    复制代码
6. 字符串到日期或时间戳,带时区的转换



  • CONVERT_TZ: 将时间戳从一个时区转换到另一个时区。
  1. -- 将UTC时间戳转换为东八区时间
  2. SELECT CONVERT_TZ('2024-08-24 06:00:00', '+00:00', '+08:00');
复制代码
7. 字符串直接转换为时间戳



  • 如果字符串格式与时间戳的默认格式同等,可以直接进行转换,这会主动将字符串转换为时间戳。留意这种方法仅适用于字符串格式准确匹配默认的DATETIME格式。
  1. SELECT '2024-08-24 14:30:00' + 0 AS timestamp_value;
复制代码
常用的格式化符号:



  • %Y 年(四位)
  • %m 月(两位)
  • %d 日(两位)
  • %H 小时(24小时制)
  • %i 分钟
  • %s 秒

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

半亩花草

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表