1

我需要根据月份或顺序而不是按字母顺序对行进行排序。

当我运行下面的查询时,我得到以下结果

Col Mon Tue Wed Thu Fri
--- --- --- --- --- ---
Feb 1   2   3   4   5
Jan 2   3   4   5   6 
Mar 3   4   5   6   7

我怎样才能按如下方式订购:

Col Mon Tue Wed Thu Fri
--- --- --- --- --- ---
Jan 2   3   4   5   6 
Feb 1   2   3   4   5
Mar 3   4   5   6   7

我的查询:

select *
from
(
  select LEFT(datename(dw,datetime),3) as DateWeek,
    col, 
    value
  from DataTable
  cross apply 
  (
    values ('Jan', JData), ('Feb', FData),  ('Mar', MData)
  ) c (col, value)
) src
pivot
(
  sum(value)
  for dateweek in (Mon, Tue, Wed, Thu, Fri)
) piv

目前我将值的行替换为:

values ('1.Jan', JData), ('2.Feb', FData),  ('3.Mar', MData)

我想有更好的解决方案

4

2 回答 2

1

尝试这个:

select * from DataTable
order by convert(datetime, '2012/'+ Col +'/01') 

SQLFiddle

于 2013-03-09T15:50:23.797 回答
0

感谢 Wawrzyniec Sz.,我想出了解决方案。添加一个额外的列就可以了。

几个月的代码如下:

select col, Mon, Tue, Wed, Thu, Fri
from
(
  select LEFT(datename(dw,datetime),3) as DateWeek, 
    ord,
    col, 
    value
  from DataTable
  cross apply 
  (
    values ('1','Jan', AVol_Offered), ('2','Feb', OVol_Offered),  ('3','Mar', AAHT)
  ) c (ord, col, value)
) src
pivot
(
  sum(value)
  for dateweek in (Mon, Tue, Wed, Thu, Fri)
) piv
order by ord

这将适用于其他值,例如,如果我想保持列为 C、A、B 的顺序(您不能按 asc 或 des 排序),您也可以使用以下相同的代码:

select col, Mon, Tue, Wed, Thu, Fri
from
(
  select LEFT(datename(dw,datetime),3) as DateWeek, 
    ord,
    col, 
    value
  from DataTable
  cross apply 
  (
    values ('1','C', AVol_Offered), ('2','A', OVol_Offered),  ('3','B', AAHT)
  ) c (ord, col, value)
) src
pivot
(
  sum(value)
  for dateweek in (Mon, Tue, Wed, Thu, Fri)
) piv
order by ord

感谢您的帮助/提示

于 2013-03-09T16:55:40.940 回答