一个表,需要来自不同行/元组的多个值

时间:2010-06-17 00:30:48

标签: sql mysql drupal pivot

我有以下表格:

'profile_values'
userID | fid     | value  
-------+---------+-------
1      | 3       | joe@gmail.com
1      | 45      | 203-234-2345
3      | 3       | jane@gmail.com
1      | 45      | 123-456-7890

'users'
userID | name       
-------+-------
1      | joe      
2      | jane     
3      | jake    

我想加入他们并拥有一行包含两个值,如:

'profile_values'
userID | name  | email          | phone
-------+-------+----------------+--------------
1      | joe   | joe@gmail.com  | 203-234-2345
2      | jane  | jane@gmail.com | 123-456-7890

我已经解决了它,但感觉很笨拙,我想知道是否有更好的方法来做到这一点。意味着解决方案更易读或更快(优化)或只是最佳实践。

当前解决方案:选择了多个表,许多条件语句:

SELECT u.userID AS memberid,
       u.name AS first_name, 
       pv1.value AS fname,
       pv2.value as lname
FROM  users AS u,
      profile_values AS pv1, 
      profile_values AS pv2,
WHERE u.userID = pv1.userID
  AND pv1.fid = 3
  AND u.userID = pv2.userID
  AND pv2.fid = 45;

感谢您的帮助!

2 个答案:

答案 0 :(得分:5)

这是典型的数据透视查询:

  SELECT u.userid,
         u.name,
         MAX(CASE WHEN pv.fid = 3 THEN pv.value ELSE NULL END) AS email,
         MAX(CASE WHEN pv.fid = 45 THEN pv.value ELSE NULL END) AS phone,
    FROM USERS u
    JOIN PROFILE_VALUES pv ON pv.userid = u.userid
GROUP BY u.userid, u.name

如果您想查看PROFILE_VALUES表中没有任何条目的用户,请在“加入”前添加“LEFT”。

答案 1 :(得分:0)

我没有说这个,我应该(@OMG Ponies),但我想在MySQL视图中使用它。要使视图可编辑,您不能使用聚合函数和other constraints。所以我必须做的就是使用与我在初始问题中描述的相同的SQL查询。

希望这可以帮助某人,添加用于创建视图的标记。