Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

SSRS 2005 trouver le nom de la colonne avec la valeur maximale

Vous pouvez utiliser le UNPIVOT fonction et un CROSS APPLY pour obtenir ceci :

;with cte as
(
  select col, value
  from yourtable
  unpivot
  (
    value
    for col in ([Step X], [Step W], [Step A], [Step B], [Step Y])
  ) unpiv
) 
select [Step X], 
  [Step W], 
  [Step A], 
  [Step B], 
  [Step Y],
  d.col LastStep
from yourtable
cross apply
(
  select c1.col
  from cte c1
  inner join
  (
    select max(value) MaxDate
    from cte
  ) c2
    on c1.value = c2.maxdate
) d

Voir SQL Fiddle avec démo