Spark sql 常用时间函数 to_date ,datediff

1. to_date

`to_date` 是 Apache Spark 中的一个函数,用于将字符串或其他日期/时间格式转换为日期格式。这个函数通常在处理日期字符串时非常有用,尤其是当你需要将它们转换为标准的日期格式以进行进一步的操作或分析时。

例如,假设你有一个包含日期字符串的 DataFrame,并且这些字符串的格式为 "yyyy-MM-dd",你可以使用 `to_date` 函数将这些字符串转换为日期格式:

Scala 复制代码
import org.apache.spark.sql.functions._

val df = Seq("2022-01-01", "2022-01-02").toDF("date_string")
val dfWithDate = df.withColumn("date", to_date(col("date_string"), "yyyy-MM-dd"))
dfWithDate.show()

输出:

+-----------+--------------+

|date_string| date |

+-----------+--------------+

| 2022-01-01|2022-01-01|

| 2022-01-02|2022-01-02|

+-----------+------------------+


2.datediff

`datediff` 函数是 Spark SQL 中的一个日期函数,用于计算两个日期之间的天数差异。它接受两个日期作为输入,并返回两个日期之间的天数差。

函数原型如下:

Scala 复制代码
datediff(enddate: Column, startdate: Column): Column

其中,`enddate` 和 `startdate` 是两个日期列或者日期值。

下面是一个示例:

Scala 复制代码
import org.apache.spark.sql.functions.datediff
import org.apache.spark.sql.SparkSession

val spark = SparkSession.builder()
                        .appName("datediff example")
                        .getOrCreate()

import spark.implicits._

val df = Seq(("2021-01-01", "2021-01-10"), ("2021-02-01", "2021-02-10")).toDF("startdate", "enddate")

df.withColumn("diff", datediff($"enddate", $"startdate"))
  .show()

输出结果为:

+----------+----------+----+

| startdate| enddate|diff|

+----------+----------+----+

|2021-01-01|2021-01-10| 9|

|2021-02-01|2021-02-10| 9|

+----------+----------+----+

可以看到,`datediff` 函数计算了 `startdate` 到 `enddate` 之间的天数差异,并将结果添加到了新的一列 `diff` 中。


相关推荐
麦聪聊数据1 小时前
利用实时数据管道与 SQL2API 重构企业自动化审计架构
数据库·sql·低代码
麦聪聊数据1 小时前
重构开放生态:利用 QuickAPI 跨越遗留系统与敏捷交付的工程实践
数据库·sql·低代码·restful
金融小师妹10 小时前
基于多模态宏观建模与历史序列对齐:原油能源供给冲击的“类1970年代”演化路径与全球应对机制再评估
大数据·人工智能·能源
播播资源10 小时前
OpenAI2026 年 3 月 18 日最新 gpt-5.4-nano模型:AI 智能体的“神经末梢”,以极低成本驱动高频任务
大数据·人工智能·gpt
GJGCY11 小时前
中小企业财务AI工具技术评测:四大类别架构差异与选型维度
大数据·人工智能·ai·架构·财务·智能体
九河云11 小时前
云上安全运营中心(SOC)建设:从被动防御到主动狩猎
大数据·人工智能·安全·架构·数字化转型
武子康11 小时前
大数据-252 离线数仓 - Airflow + Crontab 入门实战:定时调度、DAG 编排与常见报错排查
大数据·后端·apache hive
小王不爱笑13211 小时前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
jinanwuhuaguo11 小时前
OpenClaw、飞书、Claude Code、Codex:四维AI生态体系的深度解构与颗粒化对比分析
大数据·人工智能·学习·飞书·openclaw
Rubin智造社12 小时前
# OpenClaude命令实战|核心控制三剑客/reasoning+/verbose+/status 实操指南
大数据·人工智能