2013-05-06 92 views
1

我在Access编码方面不是很熟练,我更喜欢使用SQL。我有一个代码,用于在特定领域吸引一些员工。但是有一张桌子有员工全部历史记录,所以我在REC EFF STT DT领域进行了抽签,当时他们可能已经开始了每个职位。我只需要最近一次(他们目前的)工作。我知道我需要WHERE语句中的子查询,包括MAX DATE,但我无法弄清楚如何正确格式化它。Access中的子查询

SELECT O896IA_VEMPPRSA.EMP_NA, O896IA_VEMPPRSA.SYS_EMP_ID_NR, 
    ([O896IA_VEMPPRSA].[REG_NR]) & ([O896IA_VEMPPRSA].[DIS_NR]) AS RRDD, 
    O867IA_VJOBHST.BUS_UNT_REF_NR, O867IA_VJOBHST.REC_EFF_STT_DT 
FROM O867IA_VJOBHST 
INNER JOIN O896IA_VEMPPRSA 
    ON O867IA_VJOBHST.SYS_EMP_ID_NR = O896IA_VEMPPRSA.SYS_EMP_ID_NR 
WHERE (((([O896IA_VEMPPRSA].[REG_NR]) & ([O896IA_VEMPPRSA].[DIS_NR])) 
     IN ("2010","2108","2029","2230","2580")) AND 
     ((O867IA_VJOBHST.BUS_UNT_REF_NR) IN  
     ("ISBOP","ISCIM","ISGAP","ISCRA","ISCTP","ISOPS","ISSCS","ISSSP","ISTTG"))) 
GROUP BY O896IA_VEMPPRSA.EMP_NA, O896IA_VEMPPRSA.SYS_EMP_ID_NR, 
     ([O896IA_VEMPPRSA].[REG_NR]) & ([O896IA_VEMPPRSA].[DIS_NR]), 
     O867IA_VJOBHST.BUS_UNT_REF_NR, O867IA_VJOBHST.REC_EFF_STT_DT; 

我不能简单地使用MAX DATE,因为它会包含他们每次工作的记录。我只需要他们当前的那个,这是他们最近的日期。

回答

1

你应该能够在您的WHERE子句中添加一个条件:

and O867IA_VJOBHST.REC_EFF_STT_DT = (select max([hist].REC_EFF_STT_DT) 
from O867IA_VJOBHST as [hist] 
where [hist].SYS_EMP_ID_NR = O896IA_VEMPPRSA.SYS_EMP_ID_NR) 

这个假设不会有两个条目具有相同最大日期。

+0

非常感谢。 – user2119980 2013-05-06 19:18:00