我现在已经尝试了一段时间。我尝试了UNION和假(一个左和一个右连接)完全加入。我对sql不太好,所以也许我偶然发现了解决方案,但无法做到这一点。
对于这个例子,我有三个表(我可能有更多的时间)。
post:
----------------------------
| type | rel_id | id |
----------------------------
| video | 2 | 51 |
|----------------------------|
| text | 1 | 50 |
----------------------------
video:
----------------------------
| id | video_url | title |
----------------------------
| 2 | ... | ... |
|----------------------------|
| 1 | ... | ... |
----------------------------
text:
----------------
| id | contend |
----------------
| 2 | ... |
|----------------|
| 1 | ... |
----------------
邮政表是主表。 type字段显示要加入的表。字段rel_id说明要连接的行。
我可以使用这样的输出:
------------------------------------------
| id | type | video_url | title | contend |
------------------------------------------
| 51 | video | ... | ... | NULL |
|------------------------------------------|
| 50 | text | NULL | NULL | ... |
------------------------------------------
最后一个问题是最后一个WHERE子句需要是空闲的,以便我可以用它来搜索所有结果。
答案 0 :(得分:0)
你可以尝试:
SELECT p.id AS id, p.type AS type, v.video_url AS video_url,
v.title AS title, NULL AS contend
FROM post p INNER JOIN video v
ON p.rel_id = v.id AND p.type = 'video'
UNION
SELECT p.id, p.type, NULL, NULL, t.contend
FROM post p INNER JOIN text t
ON p.rel_id = t.id AND p.type = 'text'