首页 > 数据库 >MySQL中日期和时间戳的转换:字符到DATE和TIMESTAMP的相互转换

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

时间:2024-09-01 12:24:17浏览次数:13  
标签:00 转换 TIMESTAMP 字符串 UNIX MySQL DATE SELECT

在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

标签:00,转换,TIMESTAMP,字符串,UNIX,MySQL,DATE,SELECT
From: https://blog.csdn.net/promise524/article/details/141506958

相关文章

  • mysqlbackup处理过程说明
    InnoDBdatafiles,redolog,binarylog,和relaylogfiles(除了正在使用的log文件)被拷贝到备份,这个期间数据库服务可以想平常一样使用innodb的表结构和数据可能在这个期间发生变化,所以下面的步骤就是确保这些变化被捕捉到备份中一个backuplock会被应用到服务器实例上,他会阻塞DD......
  • MySQL的索引原理及使用
    MySQL中的索引模型Mysql中的索引使用的数据结构一般为搜索树,这里的搜索树,一般使用B树,这里补一下数据结构中的B树结构;说B树之前,先顺一个前置的知识点,平衡二叉树;平衡二叉树二叉树应该都不陌生,大学数据结构的基本入门,二叉排序树是基于二叉树上多了个“有序”的概念,简单来说,即左<......
  • MySQL的索引原理及使用
    索引模型(基础数据结构)索引模型:哈希表、有序数组、搜索树,这里的模型是指索引的底层实现的基本数据结构,Mysql中不同的引擎对于索引的实现结构说的即是索引模型。 有序数组有序数组这个在数据结构中是最基础的结构,也是最简单的,对比理解的话就是我们编程中常用的数组、链表,它......
  • 超长二进制利用Integer转换
    1.Integer缺点目前测试Integer只能一次性转4*7位二进制数,也就是7位16进制,故进行改进2.改进操作:每四位二进制一转换,以免到上限报错注解格式:序号(代码顺序)+解释publicclassMain{publicstaticvoidmain(String[]args){//1.测试文本:创建int数组放入16......
  • 【从头写CAD】 转换矩阵类系列八,代码汇总
    为了找出优化代码的方案,梳理矩阵类现有代码。现汇总转换矩阵所有代码在同一个文件中,同时调整了与矩阵类重载的代码的先后次序。完整代码如下:/*矩阵类编程思路总说明:平面CAD对象主要包括点(point)、线(line含线段、直线、射线,宽线、多段线)、平面形状(shap含矩形、圆形、椭......
  • 可重复读隔离级别真的完全解决不可重复读问题了吗?读已提交隔离级别能避免不可重复读问
    一文带你搞懂MySQL事务的各个疑惑,不要再在脑子里一团浆糊啦!!事务的四大特性MySQL的三种日志事务的原子性是如何保证的?事务的隔离性是如何保证的?事务的持久性是如何保证的?数据库事务的隔离级别各隔离级别都各自解决了什么并发问题?什么是MVCC?读已提交和可重复读隔离级别实......
  • 20240904_070346 mysql 存储过程 认识
    什么是存储过程存储过程的特点......
  • 20240904_080346 mysql 存储过程 创建与使用存储过程
    存储过程的使用修改结束符号将默认的句子结束符号由;改为$号的写法创建存储过程调用存储过程......
  • 20240904_090346 mysql 存储过程 查看表中的全部存储过程
    查看格式相关表格实操演示SELECT*FROMinformation_schema.routinesWHEREROUTINE_SCHEMA="my_school";......
  • 20240904_100346 mysql 存储过程 查看存储过程中的语句
    说明用法和查建表语句是一样的实操查到的完整内容为......