[英]How can I display fields from two different tables using active record of left join in codeigniter?
[英]How to left join two tables and display info?
我有3張桌子:
具有id
和name
列的miners
;
users
的列id
, name
和password
;
user_miners
的列user_id
和miner_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.