1

我有以下表格:

Table: user
Columns
- id
- username
- full_name

Table: pet
Columns
- id
- pet_name

Table: results
Columns
- id
- user_id_1
- user_id_2
- user_id_3
- pet_id
- date
- some_text

我可以做一个 SQL 查询,女巫会给我一行:id、full_name、full_name、full_name、pet_name、date、some_text,其中 results.id 是 3?

4

2 回答 2

4
select  u1.full_name
,       u2.full_name
,       u3.full_name
,       p.pet_name
,       r.date
,       r.some_text
from    Results r
join    User u1
on      u1.id = r.user_id_1
join    User u2
on      u2.id = r.user_id_2
join    User u3
on      u3.id = r.user_id_3
join    pet p
on      p.id = r.pet_id
where   r.id = 3
于 2013-06-30T12:40:35.297 回答
0

尝试以下查询:

SELECT A.id, B.full_name, C.full_name, D.full_name, E.pet_name, A.date, A.some_text
FROM RESULTS AS A 
LEFT OUTER JOIN USER AS B ON A.USER_ID1 = B.ID
LEFT OUTER JOIN USER AS C ON A.USER_ID2 = C.ID
LEFT OUTER JOIN USER AS D ON A.USER_ID3 = D.ID
LEFT OUTER JOIN PET AS E ON A.PET_ID = E.ID
WHERE A.id = 3
于 2013-06-30T13:16:39.373 回答