sql – 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

查询产生以下错误

3504 : Selected non-aggregate values must be part of the associated group

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

解决方法

正如Ponies在评论中所说,您不能将OLAP函数与聚合函数混合使用.

也许更容易获得每个员工的最后完成日期,并将其加入到包含三个目标课程中每个目标课程的最后完成日期的数据集中.

这是一个未经考验的想法,希望能让你走上正确的道路:

SELECT employee_number,course_code,MAX(course_completion_date) AS max_date,lcc.LAST_COURSE_COMPLETED
    FROM employee_course_completion ecc
         LEFT JOIN (
             SELECT employee_number,MAX(course_completion_date) AS LAST_COURSE_COMPLETED
               FROM employee_course_completion
              WHERE course_code IN ('M910303','M91301P')
         ) lcc
         ON lcc.employee_number = ecc.employee_number
   WHERE course_code IN ('M910303','M91301P')
GROUP BY employee_number,lcc.LAST_COURSE_COMPLETED

相关文章

(一)日志传送架构 (1.1)相关服务器 主服务器 :用于生产的服务器,上面运行这生产SQL Server数据库...
(一)事故背景 最近在SQL Server 2012生产数据库上配置完事物复制(发布订阅)后,生产数据库业务出现了...
(一)测试目的 目前公司使用的SQL SERVER 2012高可用环境为主备模式,其中主库可执行读写操作,备库既...
(一)背景个人在使用sql server时,用到了sql server的发布订阅来做主从同步,类似MySQL的异步复制。在...
UNION和OR谓词 找出 product 和 product2 中售价高于 500 的商品的基本信息. select * from product wh...
datawhale组队学习task03