我需要 SELECT 查询的帮助,在该查询中我需要加入另一个表并获取最大日期的记录。我创建了示例来演示。我的最后一个 SELECT 不正确,我需要指导来修复它,或者 Sql server 2014 中是否有更好的方法
CREATE TABLE #EmpTable
(
EmpNum INT,
colA VARCHAR(5) NULL,
colB VARCHAR(5) NULL
)
CREATE TABLE #EmpDetailTbl
(
EmpNum INT,
Name VARCHAR(10),
Department VARCHAR(10) NULL,
ReportDate DATETIME NOT NULL
)
INSERT INTO #EmpTable
VALUES (101, 'val11', 'Val21'), (102, 'val12', 'Val21'), (103, 'val13', 'Val23');
INSERT INTO #EmpDetailTbl
VALUES (101, 'emp101', 'Dept1', '05/01/2018'), (101, 'emp101', 'Dept2', '06/01/2018'),
(101, 'emp101', 'Dept1', '05/01/2017'), (102, 'emp102', 'Dept3', '04/01/2018'),
(102, 'emp102', 'Dept1', '05/01/2018')
--select * from #EmpDetailTbl
--select * from #EmpTable
SELECT
a.EmpNum, Name, ColA, ColB, Department
FROM
#EmpTable a
LEFT OUTER JOIN
#EmpDetailTbl b ON a.EmpNum = b.EmpNum
AND ReportDate = (SELECT MAX(ReportDate)
FROM #EmpDetailTbl
a.EmpNum = b.EmpNum)