Mysql JOIN的四个表有两个关键表

时间:2010-09-29 17:47:32

标签: mysql join mysql-error-1066

我不想承认,当涉及更复杂的查询时,我对MySQL的了解是缺乏的。基本上我有四个表,其中两个包含我想要返回的数据,两个是连接数据的关系表。 Table A仅用于为Table D.aID提供填充。

+--------+ +--------+ +--------+ +-----------+ +-----------+
|Table A | |Table B | |Table C | |  Table D  | |  Table E  |
+---+----+ +---+----+ +---+----+ +---+---+---+ +---+---+---+
|aID|name| |bID|name| |cID|name| |dID|aID|bID| |eID|dID|cID|
+---+----+ +---+----+ +---+----+ +---+---+---+ +---+---+---+
| 1 | a_1| | 1 | b_1| | 1 | c_1| | 1 | 1 | 1 | | 1 | 1 | 1 |
+---+----+ | 2 | b_2| | 2 | c_2| | 2 | 1 | 2 | | 1 | 1 | 2 |
           +---+----+ | 3 | c_3| +---+---+---+ +---+---+---+
                      +---+----+

使用这些表创建的关系是:Table A > Table B > Table C。我想要的数据属于Table B > Table C关系。

+--------+---------+--------+---------+
|tblB.bID|tblB.name|tblC.cID|tblC.name|
+--------+---------+--------+---------+
|    1   |    a_1  |    1   |   c_1   |
|    1   |    a_1  |    2   |   c_2   |
|    2   |    a_2  |  NULL  |   NULL  |
+--------+---------+--------+---------+

但是为了确保我遵循正确的路径,我需要抓住Table B Table A > Table B关系所属的Table C。我意识到我通过允许重复的name值使自己的事情变得更加困难,但我宁愿拥有小表和更复杂的查询,而不是膨胀的表和更简单的查询。我正在使用的查询是

SELECT * FROM `Table E`
LEFT JOIN `Table D` ON (`Table B`.bID = `Table D`.bID)
RIGHT JOIN `Table E` ON (`Table D`.dID = `Table E`.dID))
RIGHT JOIN `Table C` ON (`Table E.cID = `Table C`.cID);

然而到目前为止它还没有奏效。提交查询时,将返回此错误:

ERROR 1066 (42000): Not unique table/alias: 'Table D'

关于如何让它发挥作用的任何想法?这甚至可能吗?

2 个答案:

答案 0 :(得分:1)

你说你提交的查询与你给我们的表格结构几乎没有相似之处! 什么是Table D.national_regionID?或modx.coverage_state

一般情况下,不要混合左右连接。此外,查询中使用的每个表都必须遵循FROM或跟随JOIN。您似乎在加入条件中使用了Table BTable C,而没有将它们添加到查询中。

答案 1 :(得分:0)

感谢Martin Smith,我能够提出我在这里发布的解决方案。我希望这可以帮助别人。

SELECT  tblB.bID,
    tblB.name,
    tblC.cID,
    tblC.name
FROM Table E 
RIGHT JOIN Table B ON (Table B.bID = Table D.bID)
RIGHT JOIN Table D USING dID
RIGHT JOIN Table C USING cID;