2016-09-16 48 views
6

tekabül sütunlar eklemek için: Ben aşağıdaki gibi göstermek istiyoruzBen bir tablo var Microsoft SQL Server 2012.</p> <p>kullanma MİL veri kümesi

PartID |TypeSet | Setting | ObservID |TransDate 
--------------------------------------------- 
1   A 456  12 10/20/2015 
1   A 377  12 10/20/2015 
1   A 425  12 10/20/2015 
1   A 665  12 10/20/2015 
1   A 543  12 10/20/2015 
1   A 554  12 10/20/2015 
1   B 34  41 10/21/2015 
1   B 27  41 10/21/2015 
1   B 27  41 10/21/2015 
1   B 29  41 10/21/2015 
1   C 1299  12 10/20/2015 
1   C 1227  12 10/20/2015 

. PartID'de tek sıra gruplandırılmış.

PartID | A Avg | B Avg | C Avg | A ObservID | B ObservID | C ObservID 
--------------------------------------------------------------------- 
    1  503  29  1263  12    41   12 

Çok satırlı bir geri dönüş veri kümesi oluşturmama durumu için ObservID'leri görüntüleyemiyorum.

SELECT  
     PartID 
     ,[A] as 'A Average' 
     ,[B] as 'B Average' 
     ,[C] as 'C Average' 
    -- ,(ObservID) 
    --,CASE WHEN [A] = 'A Average' THEN max([ObservID]) END as 'A Ob' 
    --,CASE WHEN [B] = 'B Average' THEN max([ObservID]) END as 'B Ob' 
    -- ,CASE WHEN [C] = 'C Average' THEN max([ObservID]) END as 'C Ob' 
FROM 
(SELECT 
    PartID 
    ,TypeSet 
    ,Setting 
    --,ObservID 
    FROM #Temp1 
    ) as MeasData 
PIVOT 
(
    AVG(Setting) 
    FOR [TypeSet] in 
     ([A], [B], [C])  
) as PivotTable 

Sen İçinde ObservID almak için denedim ama bu satırları uncomment zaman, hataları meydana yukarıdaki sorguda görebilirsiniz: Bu sorgu ile A, B ve C Ortalama ile bir sorunum yok. Bazı notlar: Gözlemciler her bir TypeSet için tutarlı kalacaktır. İşte

veri var:

create table #Temp1 
(
    PartID INT 
, TypeSet VARCHAR(10) 
, Setting INT 
, ObservID INT 
, TransDate Date 
) 

INSERT INTO #Temp1(PartID, TypeSet, Setting, ObservID, TransDate) VALUES 
    (1, 'A', 456, 12, '10/20/2015'), 
    (1, 'A', 377, 12, '10/20/2015'), 
    (1, 'A', 425, 12, '10/20/2015'), 
    (1, 'A', 665, 12, '10/20/2015'), 
    (1, 'A', 543, 12, '10/20/2015'), 
    (1, 'A', 554, 12, '10/20/2015'), 
    (1, 'B', 34, 41, '10/21/2015'), 
    (1, 'B', 27, 41, '10/21/2015'), 
    (1, 'B', 27, 41, '10/21/2015'), 
    (1, 'B', 29, 41, '10/21/2015'), 
    (1, 'C', 1299, 12, '10/20/2015'), 
    (1, 'C', 1227, 12, '10/20/2015') 

MİL operasyonla mümkün benim istenen çıkış var mı? Ya da her bir Yazı Tipi için masadaki çoklu JOIN'lerin rotasını mı kullanmalıyım?

cevap

3

Sen koşullu toplanmasına kullanarak bunu yapabilirsiniz:

SELECT PartID, 
    AVG(CASE WHEN TypeSet = 'A' THEN Setting END) AS 'A Avg', 
    AVG(CASE WHEN TypeSet = 'B' THEN Setting END) AS 'B Avg', 
    AVG(CASE WHEN TypeSet = 'C' THEN Setting END) AS 'C Avg', 
    MAX(CASE WHEN TypeSet = 'A' THEN ObservID END) AS 'A ObservID', 
    MAX(CASE WHEN TypeSet = 'B' THEN ObservID END) AS 'B ObservID', 
    MAX(CASE WHEN TypeSet = 'C' THEN ObservID END) AS 'C ObservID' 
FROM #Temp1 
GROUP BY PartID 
+0

bu harika. Bana ihtiyacım olanı getirir. Tek endişem performanstır, ama aynı zamanda açıklama planlarını incelemedim ... Ama bunun için teşekkürler. – Charlie

+1

@Charlie Bu, "PIVOT" kullanarak herhangi bir sorgu kadar hızlı olmalıdır. 'PIVOT' aslında koşullu toplama için sözdizimsel şekerdir. –

0
WITH avgPivot AS 
(
    SELECT 
     PartID,[a] as A_Avg,[b] as B_Avg,[c] as C_Avg 
    FROM 
    (
    SELECT PartID, TypeSet, Setting, ObservID 
    FROM #Temp1 
) As S 
    PIVOT 
    (
    AVG(Setting) 
    FOR TypeSet in([a],[b],[c]) 
) 
    AS pvt 
), 
maxPivot AS 
(
    SELECT 
     [a] as A_ObservID, [B]B_ObservID, [c] as c_ObservID 
    FROM 
    (
    SELECT PartID, TypeSet, Setting, ObservID 
    FROM #Temp1 
) As S 
    PIVOT 
    (
    max(ObservID) 
    FOR TypeSet in([a],[b],[c]) 
) 
    AS pvt 
) 

SELECT distinct * 
FROM avgPivot M 
cross JOIN maxPivot A 
+0

Bu bana NULL verir ve çok satırlı bir veri kümesi oluşturur. – Charlie

+0

Tek sıraya ihtiyacımız var ....... – Chanukya

+0

Net olmamak için özür dilerim ama evet, PartID temelli tek satır – Charlie