我需要SQL查询的帮助才能获得表

时间:2015-12-03 22:11:27

标签: sql join rows

我可以在SQL上做类似以下的事情,我没有太多关于正在使用的表模式的信息,只有图像和目标。

表格如下所示:

ID |DEF | ATT | VALUE 
---|----|-----|----- 
1  | 10 |  9  | 1234  
1  | 10 | 10  | 00199  
1  | 10 | 11  | Eduardo 
2  | 10 |  9  | 1234  
2  | 10 | 10  | 00199 
2  | 10 | 11  | Eduardo 

这是通过这样的查询得出的:

SELECT * FROM (SELECT ID, DEF, ATT, VALUE 
               FROM table 
               WHERE DEF = 10 
               AND ID IN ( 
                 SELECT DISTINCT ID 
                 FROM table WHERE VALUE = '001' 
                        OR VALUE = 'Agu')) 
WHERE ATT IN (9, 10, 11) 

如何使其看起来像

ID | DEF |VALUE|VALUE1| VALUE2 
---|-----|-----|------|--------- 
 1 |  10 |1234 |00199 | Eduardo 
 2 |  10 |1234 |00199 | Eduardo  

或者这是如何调用的,以便我可以找到更多信息?

1 个答案:

答案 0 :(得分:0)

使用这样的pivot功能可以得到你想要的结果

SELECT
ID,
DEF,
[9] AS Value1,
[10] AS Value2,
[11] AS Value3
FROM(SELECT
ID,
DEF,
ATT,
Value
From table) as Sourcetable
Pivot (Avg(Value) FOR ATT IN ([9],[10],[11])) AS PivotTable