簡體   English   中英

如何離開聯接兩個表並顯示信息?

[英]How to left join two tables and display info?

我有3張桌子:
具有idname列的miners ;
users的列idnamepassword ;
user_miners的列user_idminer_id (外鍵與其它表)

我需要打印出用戶及其礦工的名稱,例如,我有ID為1的用戶,而他的礦工的名稱為f,s,t,所以我需要打印出:

1 f
1 s
1 t

我該如何使用左聯接?

我已經嘗試了所有可能的左聯接,但是我似乎無法使其正常工作,也許僅僅是因為我不了解左聯接的概念

    ('SELECT user_mineres.user_id, users.id, miners.name
    FROM user_mineres
    LEFT JOIN users
    ON user_mineres.user_id=users.id
    LEFT JOIN miners
    ON users.id=miners.name
    GROUP BY user_mineres.user_id ');

    foreach ($stmt as $row) 
    {
    echo $row['user_id'] . $row['name'] . "<br>";
    }

我收到列名不明確或其他語法錯誤的錯誤

您不需要group by ,只需要適當的聯接和適當的ON子句即可:

SELECT u.id, m.name
FROM users u
LEFT JOIN user_miners um ON um.user_id = u.id
LEFT JOIN miners m ON m.id = um.miner_id

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM