【问题标题】:Add row number as a new column in SQL Server在 SQL Server 中将行号添加为新列
【发布时间】:2016-07-23 16:37:27
【问题描述】:

我需要行号 1,2,3,4,5 作为下面屏幕截图中的新列..

查询:

Select 
    ROW_NUMBER() OVER (ORDER BY vgid) AS RowNumber, 
    * 
from 
    T_EMS_VGDM_RULEMST 
where 
    VGID in (156, 157, 158, 159, 165) 
order by
    CASE 
       WHEN VGID = 165 then 1    
       WHEN VGID = 158 then 2 
       WHEN VGID = 159 then 3 
       WHEN VGID = 157 then 4 
       WHEN VGID = 156 then 5 
    END

请推荐

【问题讨论】:

  • 我修改了添加 ROW_Number 的问题,但结果不正确
  • 啊。是的,它正在使用 desc...谢谢
  • (ORDER BY vgid DESC) 试过了吗?

标签: sql sql-server tsql window-functions


【解决方案1】:

是不是很简单:

Select 
    ROW_NUMBER() OVER (ORDER BY CASE 
                                   WHEN VGID = 165 then 1    
                                   WHEN VGID = 158 then 2 
                                   WHEN VGID = 159 then 3 
                                   WHEN VGID = 157 then 4 
                                   WHEN VGID = 156 then 5 
                                END) AS RowNumber
    , * 
    from T_EMS_VGDM_RULEMST 
    where VGID in (156,157,158,159,165) 
    ORDER BY CASE 
     WHEN VGID = 165 then 1    
     WHEN VGID = 158 then 2 
     WHEN VGID = 159 then 3 
     WHEN VGID = 157 then 4 
     WHEN VGID = 156 then 5 
    END

【讨论】:

  • 感谢它的工作。我们也可以避免 order by from where 条件。
  • order by 不是 where 条件。以我的经验,当你生成一个行号时,输出遵循排序,但没有 order by 就不能保证
【解决方案2】:
    Select 

ROW_NUMBER() OVER (ORDER BY vgid desc) AS RowNumber, 
 * from T_EMS_VGDM_RULEMST where VGID in (156,157,158,159,165) 
ORDER BY CASE 
 WHEN VGID = 165 then 1    
 WHEN VGID = 158 then 2 
 WHEN VGID = 159 then 3 
 WHEN VGID = 157 then 4 
 WHEN VGID = 156 then 5 
END 

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2021-12-23
    • 2010-10-20
    • 2019-03-25
    • 2022-09-27
    • 2018-09-07
    • 2017-12-08
    • 1970-01-01
    相关资源
    最近更新 更多