gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 08:01:07 26 4
gpt4 key购买 nike

我有这样的表:

'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;

感谢您的帮助!

最佳答案

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

  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 表中没有任何条目的用户,请在“JOIN”之前添加“LEFT”。

关于sql - 一张表,需要来自不同行/元组的多个值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3058136/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com