SQL Dynamic Pivot - как упорядочить столбцы - PullRequest
7 голосов
/ 14 июля 2009

Я работаю над динамическим сводным запросом к таблице, содержащей:

  • OID - OrderID
  • Размер - размер изделия
  • BucketNum - порядок того, что размеры должен идти
  • количество - сколько заказано

Столбец размера содержит различные размеры в зависимости от OID.

Итак, используя найденный код здесь , я собрал это:

DECLARE @listCol VARCHAR(2000)
DECLARE @query VARCHAR(4000)

SELECT  @listCol = STUFF(( SELECT distinct  '], [' + [size]
                           FROM     #t
                         FOR
                           XML PATH('')
                         ), 1, 2, '') + ']'


SET @query = 'SELECT * FROM
      (SELECT OID,  [size], [quantity]
            FROM #t 
            ) src
PIVOT (SUM(quantity) FOR Size
IN (' + @listCol + ')) AS pvt'


EXECUTE ( @query )

Это прекрасно работает, за исключением того, что заголовки столбцов (метки размеров) расположены не в том порядке, который основан на столбце bucketnum. В порядке в зависимости от размеров.

Я попробовал опциональный Order By после разворота, но это не работает.

Как контролировать порядок появления столбцов?

Спасибо

Ответы [ 4 ]

7 голосов
/ 14 июля 2009

Вам нужно это исправить:

SELECT  @listCol = STUFF(( SELECT distinct  '], [' + [size]
                           FROM     #t
                         FOR
                           XML PATH('')
                         ), 1, 2, '') + ']'

Чтобы вернуть столбцы в правильном порядке. Возможно, вам придется сделать что-то подобное вместо использования DISTINCT:

SELECT [size]
FROM     #t
GROUP BY [size]
ORDER BY MIN(BucketNum)
4 голосов
/ 11 июня 2015
SELECT @listCol = STUFF(
        (SELECT DISTINCT ',' + QUOTENAME(size) AS [size]
        FROM #t
        ORDER BY [size]
        FOR XML PATH('')
0 голосов
/ 23 июля 2014

У меня была та же проблема, и я попробовал решение, предложенное выше, но, вероятно, из-за моего уровня понимания, не смог заставить его работать. Я обнаружил, что простым взломом было создать таблицу Temp с правильно упорядоченными заголовками столбцов, используя операторы Order by, а затем включить в этот список переменную, которая устанавливает имена столбцов динамического сводного запроса.

например.

SELECT WeekNum INTO #T3 
FROM #T2 
GROUP BY WeekNum 
ORDER BY MIN(WeekNum) 

SELECT @ColumnName1 = ISNULL(@ColumnName1 + ',','') + QuoteName(WeekNum) 
FROM (SELECT WeekNum From #T3) AS WeekNum

работал лакомство.

Надеюсь, это кому-нибудь поможет.

0 голосов
/ 14 июля 2009

Я видел эту ссылку только сегодня, которая использует CTE для построения списка столбцов (который, по-видимому, вы могли бы заказать) на лету без необходимости динамического sql:

http://blog.stevienova.com/2009/07/13/using-ctes-to-create-dynamic-pivot-tables-in-sql-20052008/

...