小编dne*_*er3的帖子

MAX()和MAX()OVER PARTITION BY在Teradata Query中产生错误3504

我正在尝试生成一个结果表,其中包含每个课程代码的最后完成课程日期,以及每位员工最后完成的课程代码.以下是我的查询:

SELECT employee_number,
       MAX(course_completion_date) 
           OVER (PARTITION BY course_code) AS max_course_date,
       MAX(course_completion_date) AS max_date
FROM employee_course_completion
WHERE course_code IN ('M910303', 'M91301R', 'M91301P')
GROUP BY employee_number
Run Code Online (Sandbox Code Playgroud)

此查询产生以下错误:

3504 : Selected non-aggregate values must be part of the associated group
Run Code Online (Sandbox Code Playgroud)

如果我删除MAX()OVER(PARTITION BY ...)行,查询执行得很好,所以我已经将问题隔离到该行,但在搜索这些论坛和互联网后,我看不到我的意思我做错了.有人可以帮忙吗?

sql aggregate-functions teradata database-partitioning

8
推荐指数
2
解决办法
10万
查看次数