千家信息网

window和groupBy操作方法是什么

发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,这篇文章主要介绍"window和groupBy操作方法是什么",在日常操作中,相信很多人在window和groupBy操作方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对
千家信息网最后更新 2025年01月23日window和groupBy操作方法是什么

这篇文章主要介绍"window和groupBy操作方法是什么",在日常操作中,相信很多人在window和groupBy操作方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"window和groupBy操作方法是什么"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

window操作

import spark.implicits._val words = ... // streaming DataFrame of schema { timestamp: Timestamp, word: String }// Group the data by window and word and compute the count of each groupval windowedCounts = words.groupBy(  window($"timestamp", "10 minutes", "5 minutes"),  $"word").count()

window操作是连续流特有的操作,设置时间窗口大小,根据窗口大小来执行groupBy操作等。

看看dataset上的groupBy操作。

groupBy操作

定义:

def groupBy(cols: Column*): RelationalGroupedDataset = {

RelationalGroupedDataset(toDF(), cols.map(_.expr), RelationalGroupedDataset.GroupByType)

}

生成新的RelationalGroupedDataset对象。该对象最重要得方法:

 private[this] def toDF(aggExprs: Seq[Expression]): DataFrame = {    val aggregates = if (df.sparkSession.sessionState.conf.dataFrameRetainGroupColumns) {      groupingExprs ++ aggExprs    } else {      aggExprs    }    val aliasedAgg = aggregates.map(alias)    groupType match {      case RelationalGroupedDataset.GroupByType =>        Dataset.ofRows(df.sparkSession, Aggregate(groupingExprs, aliasedAgg, df.logicalPlan))      case RelationalGroupedDataset.RollupType =>        Dataset.ofRows(          df.sparkSession, Aggregate(Seq(Rollup(groupingExprs)), aliasedAgg, df.logicalPlan))      case RelationalGroupedDataset.CubeType =>        Dataset.ofRows(          df.sparkSession, Aggregate(Seq(Cube(groupingExprs)), aliasedAgg, df.logicalPlan))      case RelationalGroupedDataset.PivotType(pivotCol, values) =>        val aliasedGrps = groupingExprs.map(alias)        Dataset.ofRows(          df.sparkSession, Pivot(Some(aliasedGrps), pivotCol, values, aggExprs, df.logicalPlan))    }  }

我们就看一个吧:

Dataset.ofRows(df.sparkSession, Aggregate(groupingExprs, aliasedAgg, df.logicalPlan))

看看它的实现机制是怎样得?

这里得Aggregate是一种LogicPlan,我们只要看看Aggregate的实现机制就可以了。

Aggregate的实现机制就要涉及到catalyst包里的相关类了。

到此,关于"window和groupBy操作方法是什么"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!

0