SQL查询问题转换MySQL

时间:2014-01-08 14:44:21

标签: mysql sql pivot transpose

有2个简单的表格

People:
person_id
Name 

Reading assestment
date
person_id
quality
speed

尝试创建SQL查询

SELECT 
  AVG(r.quality),
  AVG(r.speed),
FROM reading_assestment r,people p
where r.person_id =p.person_id
  and person_id="3"

当前输出:

Quality  Speed
77      65   

结果我正在寻找:

Assestment Value
Quality      77
Speed        65

这与转置,枢轴有关。

2 个答案:

答案 0 :(得分:1)

最常用的方法是从查询开始,然后使用单独的逻辑取消忽略:

select (case when n = 1 then 'Quality' else 'Speed' end) as Assessment,
       (case when n = 1 then avg_quality else avg_speed end) as Value
from (select AVG(r.quality) as avg_quality, AVG(r.speed) as avg_speed
      from reading_assestment r join
           people p
           on r.person_id =p.person_id
      where person_id = 3
     ) t cross join
     (select 1 as n union all select 2) n

答案 1 :(得分:0)

SELECT
  AggResults.person_id   AS person_id,
  Assesment.Name         AS AssessmentName,
  CASE WHEN Assessment.Name = 'Quality' THEN AggResults.AvgQuality
       WHEN Assessment.Name = 'Speed'   THEN AggResults.AvgSpeed
                                        ELSE NULL
  END                    AS AssessmentValue
FROM
(
  SELECT
    people.person_id   AS person_id,
    AVG(quality)       AS AvgQuality,
    AVG(speed)         AS AvgSpeed
  FROM
    reading_assessment
  INNER JOIN
    people
      ON reading_assessment.person_id = people.person_id
  GROUP BY
    people.person_id
)
  AS AggResults
CROSS JOIN
(
  SELECT 'Quality' AS Name
  UNION ALL
  SELECT 'Speed'   AS Name
)
  AS Assessment
WHERE
  AggResults.person_id = 3

我将= 3移到外部查询,只是为了方便使用。大多数优化者都会同样对待这两种选择。