首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将mysql中同一表中的两个字段连接起来

将mysql中同一表中的两个字段连接起来
EN

Stack Overflow用户
提问于 2015-10-25 09:50:13
回答 2查看 1.9K关注 0票数 1
代码语言:javascript
复制
SELECT  pms.id, 
                    pms.id_from, 
                    pms.id_to, 
                    pms.fecha, 
                    pms.leida, 
                    usuarios.img_src  as avatar_from, 
                    usuarios.alias as name_from,
                    usuarios.img_src  as avatar_to, 
                    usuarios.alias as name_to  
FROM pms 
LEFT JOIN usuarios ON usuarios.id = pms.id_from
LEFT JOIN usuarios ON usuarios.id = pms.id_to

这个问题是每个行都有两个对usuario (别名或img_src)的引用:

我得到了一个错误:

代码语言:javascript
复制
The following errors were reported:
Not unique table/alias: 'usuarios'

或者这个

代码语言:javascript
复制
SELECT  pms.id, 
                pms.id_from, 
                pms.id_to, 
                pms.fecha, 
                pms.leida, 
                usuarios.img_src  as avatar_from, 
                usuarios.alias as name_from,
                usuarios.img_src  as avatar_to, 
                usuarios.alias as name_to  
FROM pms 
LEFT JOIN usuarios ON usuarios.id = pms.id_from OR usuarios.id = pms.id_to

工作,但每个_to和_from的名称和图像相同。

那么,这里怎么走呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-10-25 09:55:05

是的,加入同一个表将需要表名的唯一别名,例如

代码语言:javascript
复制
select 
p.id,
p.id_from, 
p.id_to, 
p.fecha, 
p.leida, 
u1.img_src  as avatar_from, 
u1.alias as name_from,
u2.img_src  as avatar_to, 
u2.alias as name_to  
from pms p
LEFT JOIN usuarios u1 ON u1.id = p.id_from
LEFT JOIN usuarios u2 ON u2.id = p.id_to
票数 3
EN

Stack Overflow用户

发布于 2015-10-25 09:55:18

如果使用同一表两次,则需要不同的别名。

代码语言:javascript
复制
SELECT  pms.id, 
        pms.id_from, 
        pms.id_to, 
        pms.fecha, 
        pms.leida, 
        u_from.img_src  as avatar_from, 
        u_from.alias as name_from,
        u_to.img_src  as avatar_to, 
        u_to.alias as name_to 
FROM pms 
LEFT JOIN usuarios u_from ON u_from.id = pms.id_from
LEFT JOIN usuarios u_to ON u_to.id = pms.id_to
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33328322

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档