从一个 table 中获取 ID,从另一个 table 中获取 return 相关名称

Take ID from one table and return related name from another table

下面列出了两个表格:

Transactions
ID | Buyer | Seller
-------------------
 1 |   1   |   2
 2 |   1   |   3
 3 |   2   |   3

ClientData
ID | Name
---------
 1 | John
 2 | Terry
 3 | Bob

我希望能够 运行 一个查询,该查询将 return 交易 ID 和客户名称而不是买家和卖家 ID。我知道 JOIN 将用于此目的,但我 运行 遇到的所有示例似乎都只适用于单个相关 ID,这需要在查询中执行两次。 JOIN 是执行此操作的正确方法,还是我应该查看查询中的子查询?

SELECT Transactions.ID, Transactions.Buyer, Transactions.Seller 
FROM Transactions 
INNER JOIN ClientData ON Transactions.Buyer=ClientData.ID
AND Transaction.Seller=ClientData.ID

此查询没有 return 任何数据,如果我远程

AND Transaction.Seller=ClientData.ID

从查询中它只是 return 原始交易数据。以前我只是将原始交易数据读入一个数组,然后我会循环遍历该数组并手动将买家和卖家 ID 替换为客户名称,但效率极低。

这对你有用吗?

SELECT t.ID, b.Name, s.Name 
FROM Transactions t
INNER JOIN ClientData b ON t.Buyer=b.ID
INNER JOIN ClientData s ON t.Seller=s.ID

我会使用 2 个连接,一个用于买方,一个用于卖方,如下所示:

SELECT Transactions.ID, BUYER.NAME, SELLER.NAME
FROM transactions T
JOIN Clientdata BUYER
ON T.BUYER=BUYER.ID
JOIN Clientdata SELLER
ON T.SELLER=SELLER.ID