0

设想

id | location_id | coordinate_type | value
 1 |           1 | lat             | 17.3111
 2 |           1 | lng             | 45.5293978
 3 |           2 | lat             | 37.3111
 4 |           2 | lng             | 21.4646422
 5 |           3 | lat             | 37.3451
 6 |           3 | lng             | 25.529648
 7 |           4 | lat             | 37.3111
 8 |           4 | lng             | 13.688902
 9 |           5 | lat             | 37.3111
10 |           5 | lng             | 22.523535

查询结果:

location_id | lng            | lat
          1 | 45.5293978     | 17.3111
          2 | 21.4646422     | 37.3111
          3 | 25.529648      | 37.3451
          4 | 13.688902      | 37.3111
         ...

如何以最佳性能获得该结果?

4

2 回答 2

2

Try this

select location_id
,MAX(CASE WHEN coordinate_type = 'lng' THEN value ELSE NULL END) AS 'lng'
, MAX(CASE WHEN coordinate_type = 'lat' THEN value ELSE NULL END) AS 'lat'
from Table1
GROUP BY location_id

SQL FIDDLE DEMO

于 2013-08-28T15:31:12.453 回答
0

您可以添加索引(coordinate_type, location_id, value),然后尝试以下查询:

SELECT 
    t_lat.location_id ,
    t_lat.value AS latitude ,
    t_lng.value AS longitude 
FROM 
    tableX AS t_lat
  JOIN
    tableX AS t_lng
      ON t_lat.location_id = t_lng.location_id
WHERE
    t_lat.coordinate_type = 'lat'
  AND
    t_lng.coordinate_type = 'lng' ;
于 2013-08-28T15:41:42.013 回答