2013-05-30 38 views
2

我尝试在SQL Server中获得另一个select的结果集的最大值,但无法获得。我不知道我在SQL Server中做了什么不正确。任何帮助都会很棒。SQL Server:选择带子选择的最大值

这是我的SQL:

select 
    max(A.ID), A.Name, A.RMName, A.RName, A.DName, A.Section, A.CF, A.PPV, A.ESD, 
    A.EED, A.EJ, 
    A.NJ, A.NAF, A.L4MAF, A.L4MJ, A.MLF, A.PL, A.PN, A.EMSFL, A.PV, A.FName, 
    A.FLevel, A.SC, A.PID, A.PFID 
from (
     select distinct 
      ID, Name, RMName, RName, DName, Section, CF, PPV, 
      REPLACE(CONVERT (VARCHAR, ESD, 6), ' ', '-') ESD, 
      REPLACE(CONVERT (VARCHAR, EED, 6), ' ', '-') EED, 
      REPLACE(REPLACE(REPLACE(EJ, CHAR(10), ''), CHAR(13), ''), CHAR(9), '') as EJ, 
      REPLACE(REPLACE(REPLACE(NJ,CHAR(10), ''), CHAR(13), ''), CHAR(9), '') as NJ, 
      NAF, 
      L4MAF, 
      REPLACE(REPLACE(REPLACE(L4MJ,CHAR(10), ''), CHAR(13), ''), CHAR(9), '') as L4MJ, 
      MLF, 
      PL, 
      PN, 
      EMSFL, 
      PV, 
      FName, 
      FLevel, 
      SC, 
      PID, 
      PFID 
     from 
      dbo.DFD def (nolock), 
      dbo.DForm form (nolock), 
      dbo.DExcp exc (nolock) 
     where 
      exc.DPID = def.DFDID 
      and def.DFID = form.DFID 
      and NAF = 1 
      and L4MAF = 1 
      and RMName is not null 
      and EED >= GETDATE() 
      and EED <> '2050-01-01 00:00:00.000') as A 
group by 
    Name, RMName, RName, DName, Section, CF, 
    PPV, ESD, EED, EJ, NJ, NAF, L4MAF, L4MJ, 
    MLF, PL, PN, EMSFL, PV, FName, FLevel, 
    SC, PID, PFID 
+0

只是为了澄清,你是否试图获取ID为最大值的子查询中行的所有列的值? – Morfie

+0

你是什么意思,“我不能”?你有错误吗?错误的结果? – Lamak

+0

是的,我需要显示所有行中返回的所有值,并根据结果集我需要显示一个最大ID,因为所有其他字段可能在所有其他行中具有相同的数据。 –

回答

0

虽然你的问题是有些不清楚。我会根据我想你问

获取具有ID的所有行数=马克斯编号给你一个例子

SELECT 
    b.* 
FROM 
    (SELECT MAX(Id) AS [MaxId] From MyTable) a INNER JOIN 
    MyTable b ON a.MaxId = b.Id 

还有其他的方法可以做到这一点,但这样会给你您的表中有ID等于表中最大ID的所有行。如果我误解了你所得到的东西,我可以定制一个更具体的例子。

Ben