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` 中。


相关推荐
逍遥德几秒前
PostgreSQL --- 数组函数详解
数据库·sql·postgresql
大大大大晴天️6 分钟前
告别 Lambda 架构!Flink 批流一体底层原理解析
大数据·flink
weelinking11 分钟前
【产品】10_搭建前端框架——把你的原型变成真实页面
java·大数据·前端·数据库·人工智能·python·前端框架
无关868815 分钟前
StarRocks 存算分离 + Spark + Hive Metastore + MinIO 数据湖搭建全流程
大数据·hive·spark
狒狒热知识8 小时前
AI赋能下企业新闻内容优化178软文网赋能权威资讯形成持续积累效应
大数据
盘古信息IMS9 小时前
盘古信息IMS V6 8.0重磅发布:以薪火AI数智平台点燃离散制造数智化引擎
大数据·人工智能·制造
论文小助手W68510 小时前
【ACM出版,EI检索】2026年人工智能与智慧城市国际学术会议(IC-AISC 2026)
大数据·人工智能·全文检索·智慧城市·交通物流
盖小雅11 小时前
自动化排班如何破解劳动法合规难题:从规则冲突到可追溯的排班表
大数据·运维·机器学习·自动化
Bechamz11 小时前
大数据开发学习Day43
大数据·学习
lzhdim12 小时前
SQL 入门 16:SQL 事务隔离级别与死锁解析(易懂)
数据库·sql