【发布时间】:2019-01-18 16:18:27
【问题描述】:
我正在尝试获取每个客户过去 3 个月行(不包括当前行)的收入总和。当前在 Databricks 中尝试的最小示例:
cols = ['Client','Month','Revenue']
df_pd = pd.DataFrame([['A',201701,100],
['A',201702,101],
['A',201703,102],
['A',201704,103],
['A',201705,104],
['B',201701,201],
['B',201702,np.nan],
['B',201703,203],
['B',201704,204],
['B',201705,205],
['B',201706,206],
['B',201707,207]
])
df_pd.columns = cols
spark_df = spark.createDataFrame(df_pd)
spark_df.createOrReplaceTempView('df_sql')
df_out = sqlContext.sql("""
select *, (sum(ifnull(Revenue,0)) over (partition by Client
order by Client,Month
rows between 3 preceding and 1 preceding)) as Total_Sum3
from df_sql
""")
df_out.show()
+------+------+-------+----------+
|Client| Month|Revenue|Total_Sum3|
+------+------+-------+----------+
| A|201701| 100.0| null|
| A|201702| 101.0| 100.0|
| A|201703| 102.0| 201.0|
| A|201704| 103.0| 303.0|
| A|201705| 104.0| 306.0|
| B|201701| 201.0| null|
| B|201702| NaN| 201.0|
| B|201703| 203.0| NaN|
| B|201704| 204.0| NaN|
| B|201705| 205.0| NaN|
| B|201706| 206.0| 612.0|
| B|201707| 207.0| 615.0|
+------+------+-------+----------+
如您所见,如果在 3 个月窗口中的任何位置都存在空值,则返回空值。我想将空值视为 0,因此尝试 ifnull,但这似乎不起作用。我还尝试了一个 case 语句将 NULL 更改为 0,但没有运气。
【问题讨论】:
-
为什么/这与 MySQL 有什么关系?这似乎是 apache spark?
-
而 MySQL 得到了正确的结果:db-fiddle.com/f/gabXH7MRvJbymL9fESAzrU/0
-
我怀疑问题在于
IFNULL()没有将NaN视为NULL。 -
试试
SUM(IF(Revenue = NaN, 0, Revenue))
标签: apache-spark null apache-spark-sql window-functions