MySQL和Hive SQL 时间处理常用函数汇总

文章目录

以下是 SQL 中常用的时间处理函数汇总,涵盖 MySQLHive 的差异:

一、基础时间函数
功能 MySQL Hive
当前时间(日期 + 时间) NOW() / CURRENT_TIMESTAMP() current_timestamp()
当前日期 CURDATE() / CURRENT_DATE() current_date()
当前时间 CURTIME() current_time()
二、日期加减操作
功能 MySQL Hive
日期增加 / 减少 DATE_SUB(date, INTERVAL n DAY) date_sub(date, n)
月份增加 / 减少 DATE_SUB(date, INTERVAL n MONTH) add_months(date, n)
年份增加 / 减少 DATE_SUB(date, INTERVAL n YEAR) date_sub(date, n * 365)(近似)
时间增加秒数 DATE_ADD(time, INTERVAL n SECOND) date_add(time, n)
三、日期格式化与解析
功能 MySQL Hive
格式化日期 DATE_FORMAT(date, format) date_format(date, format)
解析字符串为日期 STR_TO_DATE(str, format) from_utc_timestamp(unix_timestamp(str), 'Asia/Shanghai')
提取年份 YEAR(date) year(date)
提取月份 MONTH(date) month(date)
提取日期 DAY(date) day(date)
提取季度 QUARTER(date) quarter(date)
四、时间差计算
功能 MySQL Hive
日期差(天数) DATEDIFF(end_date, start_date) datediff(end_date, start_date)
时间差(秒数) TIMESTAMPDIFF(SECOND, start, end) unix_timestamp(end) - unix_timestamp(start)
五、时间类型转换
功能 MySQL Hive
时间戳转日期 FROM_UNIXTIME(timestamp) from_utc_timestamp(timestamp, 'Asia/Shanghai')
日期转时间戳 UNIX_TIMESTAMP(date) unix_timestamp(date)
字符串转时间戳 UNIX_TIMESTAMP(str, format) unix_timestamp(str, format)
六、时区处理
功能 MySQL Hive
转换时区 CONVERT_TZ(time, from_tz, to_tz) from_utc_timestamp(time, 'Asia/Shanghai')
示例
获取当前时间并格式化
sql 复制代码
MySQL: SELECT DATE_FORMAT(NOW(), '%Y-%m-%d %H:%i:%s')
Hive: SELECT date_format(current_timestamp(), 'yyyy-MM-dd HH:mm:ss')
日期增加 3 天
sql 复制代码
MySQL: SELECT DATE_SUB('2025-03-07', INTERVAL 3 DAY)
Hive: SELECT date_sub('2025-03-07', 3)
计算两个日期的天数差
sql 复制代码
MySQL: SELECT DATEDIFF('2025-03-10', '2025-03-07')
Hive: SELECT datediff('2025-03-10', '2025-03-07')
注意事项:
  • MySQLHive 的函数名称和参数顺序可能存在差异(如 Hivedate_sub 直接使用数值而非 INTERVAL)。
  • Hive 通常需要显式处理时区(如 from_utc_timestamp),而 MySQL 可通过会话时区设置简化操作。
相关推荐
盟接之桥2 小时前
盟接之桥说制造:源头制胜,降本增效:从“盟接之桥”看供应链成本控制的底层逻辑
大数据·网络·人工智能·安全·制造
数据皮皮侠2 小时前
中国绿色制造企业数据(绿色工厂|绿色供应链|绿色园区|绿色产品,2017-2023)
大数据·运维·服务器·人工智能·制造·微信开放平台
RFID舜识物联网3 小时前
NFC技术如何破解电子制造领域的效率瓶颈与追溯难题
大数据·人工智能·嵌入式硬件·物联网·安全·制造
l12345sy3 小时前
Day31_【 NLP _1.文本预处理 _(1)文本处理的基本方法】
人工智能·自然语言处理·nlp·文本基本处理·jieba词性标注对照表
Haohao+++4 小时前
Stable Diffusion原理解析
人工智能·深度学习·算法
Joseit7 小时前
AI应用生成平台:数据库、缓存与存储
数据库·人工智能·缓存
QYR_117 小时前
2025-2031年全球箱体与盒体搬运机器人行业全景报告(含市场规模、竞争格局及投资潜力)
人工智能·市场研究
迎風吹頭髮8 小时前
UNIX下C语言编程与实践9-UNIX 动态库创建实战:gcc 参数 -fpic、-shared 的作用与动态库生成步骤
c语言·数据库·unix
程序视点9 小时前
MySQL COUNT(*)性能对比:MyISAM为何比InnoDB快?全面解析与优化方案
mysql
袁总6669 小时前
智能座舱问答
人工智能