donglian1953 2012-06-05 00:58
浏览 57
已采纳

如何使用mySQL内部连接3个表?

I have joined two tables as below correctly

SELECT m.id as mid, c.id as cid FROM members m inner join companies c on m.id=c.id

and then I wanted to add a 3rd table also, but I can not get it working.

SELECT m.id as mid, c.id as cid, u.id as uid FROM members m inner join companies c on m.id=c.id inner join users u on m.id=u.id

What am I missing here?

  • 写回答

2条回答 默认 最新

  • doutu2017 2012-06-05 01:02
    关注

    Switch them from inner joins to left joins.

    If you use the inner join, and a result does not exist in all three tables, it will be excluded, appearing to fail/not return results.

    SELECT m.id as mid, c.id as cid, u.id as uid 
    FROM members m 
    left join companies c on m.id=c.id 
    left join users u on m.id=u.id
    

    That should take care of all the issues you are seeing.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算
  • ¥15 powerbuilder中的datawindow数据整合到新的DataWindow
  • ¥20 有人知道这种图怎么画吗?
  • ¥15 pyqt6如何引用qrc文件加载里面的的资源
  • ¥15 安卓JNI项目使用lua上的问题
  • ¥20 RL+GNN解决人员排班问题时梯度消失
  • ¥60 要数控稳压电源测试数据
  • ¥15 能帮我写下这个编程吗