Je suis en train de faire une PIVOT-requête sur une table de travail avec la structure:SQL Server 2008 PIVOT - Comment contrôler le contenu de la colonne
DECLARE @workingData TABLE
(
location VARCHAR(20),
name VARCHAR(50),
sales_type VARCHAR(20),
local_id VARCHAR(15),
house_description VARCHAR(40),
sales_order VARCHAR(10),
order_year INT,
amount NUMERIC(14,0)
)
La colonne nom contient l'une des deux valeurs suivantes: ' name1 'ou' name2 '. Ceux-ci doivent être utilisés dans le groupement comme décrit ci-dessous.
Je voudrais qu'il devienne une table avec les colonnes:
location
sales_type
local_id
house_description
sales_order
name1_2007
name2_2007
name1_2008
name2_2008
name1_2009
name2_2009
name1_2010
name2_2010
J'ai essayé:
SELECT
location, sales_type, local_id, house_description, sales_order,
MAX([1]) AS [name1_2007], MAX([2]) AS [name2_2007],
MAX([3]) AS [name1_2008], MAX([4]) AS [name2_2008],
MAX([5]) AS [name1_2009], MAX([6]) AS [name2_2009],
MAX([7]) AS [name1_2010], MAX([8]) AS [name2_2010],
'2010' As [Base Year]
FROM (
SELECT location, sales_type, local_id, house_description, sales_order, order_year, name, amount
,ROW_NUMBER() OVER (PARTITION BY location, sales_type, local_id, sales_order
ORDER BY order_year, name) AS seq
FROM @workingData
) AS SourceTable
PIVOT
(
MAX(amount)
FOR seq IN ([1], [2], [3], [4], [5], [6], [7], [8], [9])
) AS PivotTable
GROUP BY
location, sales_type, local_id, house_description, sales_order
Et cela fonctionne presque! ;) Mais mes valeurs ne sont pas placées dans les bonnes colonnes. Si une valeur particulière existe pour un certain emplacement, sales_type, local_id, house_description et sales_order est toujours affiché dans la colonne [1]. Mais cela devrait être déterminé sur name1
ou name2
et ses order_year
!
Je comprends que ce que je vois est un résultat direct de mon opération row_number, qui calcule la seq-colonne à 1 si une seule entrée existe. Alors peut-être que j'attaque ça de la mauvaise façon?
Quelqu'un peut-il résoudre ce problème?
Si ce n'est pas clair à partir de ce qui précède. Je voudrais prendre en charge les entrées qui ont seulement une valeur dans une seule colonne pivot, comme par exemple la colonne name1_2009. Les autres colonnes name1 og name2 doivent ensuite être définies sur NULL. – Alex