2013-05-30 3 views
2

Я пытаюсь получить максимальное значение набора результатов другого выбора в SQL Server, но не могу. Я не уверен, что я делаю неправильно в SQL Server. Любая помощь будет большой.SQL Server: выберите max с подвыбором

Это мой 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

Просто чтобы прояснить, вы пытаетесь получить значения для всех столбцов строки в подзапрос с идентификатором Максимальное значение? – Morfie

+0

Что значит «Я не способен» ?. Вы получаете ошибку ?, неправильные результаты? – Lamak

+0

Да, мне нужно отобразить все возвращаемые значения из всех строк и на основе набора результатов Мне нужно отобразить один максимальный идентификатор, так как все остальные поля могут иметь одинаковые данные во всех остальных строках. –

ответ

0

Хотя ваш вопрос несколько неясно. Я дам вам пример, основанный на том, что я думаю, что вы просите

Получить все строки, которые имеют Id = Макса Id

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

Есть другие способы сделать это, но это даст вам все строки в таблице, которые имеют Id, равный максимальному id в вашей таблице. Я могу приспособить более конкретный пример, если я неправильно понял, к чему вы клоните.

-Бен

Смежные вопросы