当前位置: 首页 > news >正文

数据库时间类型之间的转换魔法

解锁时间数据的魔法

时间,是数据库中一个充满魔法的复杂表现形式。在这篇博客中,我们将探讨在数据库中时间戳(timestamp)、日期(date)、日期时间(datetime)和字符串之间的转换技巧,覆盖主流数据库如MySQL、Oracle、SQL Server、PostgreSQL以及Spark SQL。

1. 时间戳(Timestamp)与日期(Date)之间的转换

1.1 MySQL

时间戳转为日期:
SELECT FROM_UNIXTIME(timestamp_column) AS converted_date FROM your_table;
日期转为时间戳:
SELECT UNIX_TIMESTAMP(date_column) AS converted_timestamp FROM your_table;

1.2 Oracle

时间戳转为日期:
SELECT TO_DATE(timestamp_column, 'YYYY-MM-DD HH24:MI:SS') AS converted_date FROM your_table;
日期转为时间戳:
SELECT TO_CHAR(date_column, 'YYYY-MM-DD HH24:MI:SS') AS converted_timestamp FROM your_table;

1.3 SQL Server

时间戳转为日期:
SELECT CONVERT(DATE, DATEADD(SECOND, timestamp_column, '19700101')) AS converted_date FROM your_table;
日期转为时间戳:
SELECT DATEDIFF(SECOND, '19700101', date_column) AS converted_timestamp FROM your_table;

1.4 PostgreSQL

时间戳转为日期:
SELECT TO_TIMESTAMP(timestamp_column) AS converted_date FROM your_table;
日期转为时间戳:
SELECT EXTRACT(EPOCH FROM date_column) AS converted_timestamp FROM your_table;

1.5 Spark SQL

时间戳转为日期:
SELECT FROM_UNIXTIME(timestamp_column) AS converted_date FROM your_table;
日期转为时间戳:
SELECT UNIX_TIMESTAMP(date_column) AS converted_timestamp FROM your_table;

2. 日期时间(Datetime)与字符串之间的转换

2.1 MySQL

日期时间转为字符串:
SELECT DATE_FORMAT(datetime_column, '%Y-%m-%d %H:%i:%s') AS converted_string FROM your_table;
字符串转为日期时间:
SELECT STR_TO_DATE('2023-11-23 12:30:45', '%Y-%m-%d %H:%i:%s') AS converted_datetime FROM your_table;

2.2 Oracle

日期时间转为字符串:
SELECT TO_CHAR(datetime_column, 'YYYY-MM-DD HH24:MI:SS') AS converted_string FROM your_table;
字符串转为日期时间:
SELECT TO_DATE('2023-11-23 12:30:45', 'YYYY-MM-DD HH24:MI:SS') AS converted_datetime FROM dual;

2.3 SQL Server

日期时间转为字符串:
SELECT CONVERT(VARCHAR, datetime_column, 120) AS converted_string FROM your_table;
字符串转为日期时间:
SELECT CONVERT(DATETIME, '2023-11-23 12:30:45', 120) AS converted_datetime FROM your_table;

2.4 PostgreSQL

日期时间转为字符串:
SELECT TO_CHAR(datetime_column, 'YYYY-MM-DD HH24:MI:SS') AS converted_string FROM your_table;
字符串转为日期时间:
SELECT TO_TIMESTAMP('2023-11-23 12:30:45', 'YYYY-MM-DD HH24:MI:SS') AS converted_datetime FROM your_table;

2.5 Spark SQL

日期时间转为字符串:
SELECT DATE_FORMAT(datetime_column, 'yyyy-MM-dd HH:mm:ss') AS converted_string FROM your_table;
字符串转为日期时间:
SELECT TO_TIMESTAMP('2023-11-23 12:30:45', 'yyyy-MM-dd HH:mm:ss') AS converted_datetime FROM your_table;

3. 日期(Date)与字符串之间的转换

3.1 MySQL

日期转为字符串:
SELECT DATE_FORMAT(date_column, '%Y-%m-%d') AS converted_string FROM your_table;
字符串转为日期:
SELECT STR_TO_DATE('2023-11-23', '%Y-%m-%d') AS converted_date FROM your_table;

3.2 Oracle

日期转为字符串:
SELECT TO_CHAR(date_column, 'YYYY-MM-DD') AS converted_string FROM your_table;
字符串转为日期:
SELECT TO_DATE('2023-11-23', 'YYYY-MM-DD') AS converted_date FROM dual;

3.3 SQL Server

日期转为字符串:
SELECT CONVERT(VARCHAR, date_column, 23) AS converted_string FROM your_table;
字符串转为日期:
SELECT CONVERT(DATE, '2023-11-23') AS converted_date FROM your_table;

3.4 PostgreSQL

日期转为字符串:
SELECT TO_CHAR(date_column, 'YYYY-MM-DD') AS converted_string FROM your_table;
字符串转为日期:
SELECT TO_DATE('2023-11-23', 'YYYY-MM-DD') AS converted_date FROM your_table;

3.5 Spark SQL

日期转为字符串:
SELECT DATE_FORMAT(date_column, 'yyyy-MM-dd') AS converted_string FROM your_table;
字符串转为日期:
SELECT TO_DATE('2023-11-23', 'yyyy-MM-dd') AS converted_date FROM your_table;

4. 字符串与时间戳之间的转换

4.1 MySQL

字符串转为时间戳:
SELECT UNIX_TIMESTAMP('2023-11-23 12:30:45') AS converted_timestamp FROM your_table;
时间戳转为字符串:
SELECT FROM_UNIXTIME(1606119045) AS converted_string FROM your_table;

4.2 Oracle

字符串转为时间戳:
SELECT TO_TIMESTAMP('2023-11-23 12:30:45', 'YYYY-MM-DD HH24:MI:SS') AS converted_timestamp FROM dual;
时间戳转为字符串:
SELECT TO_CHAR('2023-11-23 12:30:45', 'YYYY-MM-DD HH24:MI:SS') AS converted_string FROM dual;

4.3 SQL Server

字符串转为时间戳:
SELECT DATEDIFF(SECOND, '19700101', '2023-11-23 12:30:45') AS converted_timestamp FROM your_table;
时间戳转为字符串:
SELECT CONVERT(VARCHAR, DATEADD(SECOND, 1606119045, '19700101'), 120) AS converted_string FROM your_table;

4.4 PostgreSQL

字符串转为时间戳:
SELECT EXTRACT(EPOCH FROM TO_TIMESTAMP('2023-11-23 12:30:45', 'YYYY-MM-DD HH24:MI:SS')) AS converted_timestamp FROM your_table;
时间戳转为字符串:
SELECT TO_CHAR(TO_TIMESTAMP(1606119045)::TIMESTAMPTZ, 'YYYY-MM-DD HH24:MI:SS') AS converted_string FROM your_table;

4.5 Spark SQL

字符串转为时间戳:
SELECT UNIX_TIMESTAMP('2023-11-23 12:30:45') AS converted_timestamp FROM your_table;
时间戳转为字符串:
SELECT FROM_UNIXTIME(1606119045) AS converted_string FROM your_table;

写在最后

在上述的介绍中,你可以看到在不同数据库中如何进行时间数据的转换。这些可以帮助你更灵活地处理数据库中的时间信息,确保你的数据分析和查询得以顺利进行。学海无涯苦作舟,只争朝夕不负时!

http://www.lryc.cn/news/249997.html

相关文章:

  • conda和pip常用命令整理
  • 英语翻译小软件 ← Python实现
  • 将项目放到gitee上
  • 【机器视觉技术】:开创人工智能新时代
  • 网易区块链,网易区块链赋能赣州脐橙数字藏品,数字指纹解决方案
  • 程序员如何兼职?
  • 教育企业CRM选择技巧
  • 算法:Java计算二叉树从根节点到叶子结点的最大路径和
  • 袖珍可穿戴手持气象仪是什么?
  • 【Azure 架构师学习笔记】- Azure Databricks (1) - 环境搭建
  • 无需繁琐编程 开启高效数据分析之旅!
  • JOSEF约瑟 剩余电流保护器 CLJ3-100A+LH30 导轨安装
  • vue3自定义指令-文本超出宽度滚动
  • uniapp在H5端实现PDF和视频的上传、预览、下载
  • Kafka报错under-replicated partitions
  • 【Python基础】字符集与字符编码
  • C# AES-128-CBC 加密
  • 【惊喜福利】Docker容器化部署nextcloud网盘,享受高速稳定的文件共享体验!
  • WPF实战项目十九(客户端):修改RestSharp的引用
  • kobs-ng 烧写nand中的uboot
  • 【Java】扫描指定目录,并找到名称中包含指定字符的所有普通文件(不包含目录),并且后续询问该用户是否要删除该文件
  • PyQt基础_008_ 按钮类控件QSpinbox
  • 3D点云目标检测:VoxelNex解读
  • opencv-利用DeepLabV3+模型进行图像分割去除输入图像的背景
  • 中国版的 GPTs:InsCode AI 生成应用
  • MySQL 学习笔记(刷题篇)
  • windows系统如何配置yarn环境变量
  • 视频中的文字水印怎么去除?这三招学会轻松去视频水印
  • Java项目学生管理系统二查询所有
  • 27.Spring如何避免在并发下获取不完整的Bean?