Bạn sẽ phải tham gia bảng b hai lần và mỗi lần sử dụng tên bảng khác nhau (b1, b2) bằng cách sử dụng as
select *
from a join b as b1 on a.to = b1.lid
join b as b2 on a.from = b2.lid
vì vậy kết quả sẽ là
--------------------------------------------
|a.uid | a.to | b1.name | a.from | b2.name |
--------------------------------------------
| 1 | 1 | one | 2 | two |
--------------------------------------------
nhưng những gì bạn có thể muốn là ngăn chặn xung đột tên - nếu bạn v.d. gọi nó từ PHP - vì vậy sau đó cũng đổi tên các cột:
select a.*, b1.name as toName, b2.name as fromName
... (rest of the query as above)