sql-server-2008 – 如何修改此t-sql查询以返回不同列名的最大值?

前端之家收集整理的这篇文章主要介绍了sql-server-2008 – 如何修改此t-sql查询以返回不同列名的最大值?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下查询
SELECT
        [Rate],[RateMon],[RateTue],[RateWed],[RateThu],[RateFri],[RateSat],[RateSun]
    FROM
        [Room]
    WHERE
        Id=@Id

而不是返回所有列,我只想返回Rate和RateMon,RateTue,RateWed,RateThu,RateFri,RateSat和RateSun之间的最大值,但我很难,因为列名称不同.

现在返回的示例结果是:

100,400,600,600

其中100是Rate,其他值对应Mon – Sun,但在这种情况下我想返回100和600.

解决方法

SELECT  [Rate],(SELECT MAX(T.[Rate])
         FROM (VALUES([RateMon]),([RateTue]),([RateWed]),([RateThu]),([RateFri]),([RateSat]),([RateSun])) AS T([Rate])
        ) AS MaxRate
FROM [Room]
WHERE Id=@Id

猜你在找的MsSQL相关文章