15

我有三个表,每个表都有一个外键。当我执行连接时,我得到重复的列。

给定

mysql> describe Family;
+---------------+-------------+------+-----+---------+-------+
| Field         | Type        | Null | Key | Default | Extra |
+---------------+-------------+------+-----+---------+-------+
| HEAD_name     | varchar(45) | NO   | PRI |         |       |
| Family_Size   | int(11)     | NO   |     |         |       |
| Gender        | char(1)     | NO   |     |         |       |
| ID_Number     | int(11)     | NO   |     |         |       |
| DOB           | date        | NO   |     |         |       |
| Supervisor_ID | int(11)     | NO   | MUL |         |       |
+---------------+-------------+------+-----+---------+-------+
6 rows in set (0.00 sec)

mysql> describe SUPERVISOR;
+-------------------+---------------+------+-----+---------+-------+
| Field             | Type          | Null | Key | Default | Extra |
+-------------------+---------------+------+-----+---------+-------+
| Supervisor_ID     | int(11)       | NO   | PRI |         |       |
| Supervisor_Name   | varchar(45)   | NO   |     |         |       |
| Supervisor_Number | decimal(10,0) | NO   |     |         |       |
| Center_ID         | int(11)       | NO   | MUL |         |       |
+-------------------+---------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql> describe CENTER;
+-----------+-------------+------+-----+---------+-------+
| Field     | Type        | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| Center_ID | int(11)     | NO   | PRI |         |       |
| Location  | varchar(45) | NO   |     |         |       |
+-----------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

我的查询语句:

SELECT * from Family
   JOIN SUPERVISOR on ( Family.Supervisor_ID = SUPERVISOR.Supervisor_ID)
   JOIN CENTER on (SUPERVISOR.Center_ID = CENTER.Center_ID); 

我的目标是从连接中获取所有列中的一行,而没有重复的列。那么我应该使用什么 SQL 语句语法呢?

4

4 回答 4

21

默认情况下,如果你使用 MySQL 将返回所有表的所有列*。您将需要在查询中显式输入列名,以便以您想要的方式检索它们。使用如下查询:

SELECT A.HEAD_name, A.Family_Size, A.Gender, A.ID_Number, A.DOB,
    B.Supervisor_ID, B.Supervisor_Name, B.Supervisor_Number,
    C.Center_ID, C.Location
FROM Family A
JOIN SUPERVISOR B on ( A.Supervisor_ID = B.Supervisor_ID)
JOIN CENTER C on (B.Center_ID = C.Center_ID);
于 2012-12-17T04:32:19.340 回答
15

该问题可以通过“USING”关键字来解决。

SELECT * from Family
   JOIN SUPERVISOR on ( Family.Supervisor_ID = SUPERVISOR.Supervisor_ID)
   JOIN CENTER on (SUPERVISOR.Center_ID = CENTER.Center_ID); 

在您的情况下,查询将变为

SELECT * FROM FAMILY 
  JOIN (SUPERVISOR JOIN CENTER USING(Center_ID)) USING(Supervisor_ID);

要点很简单,如果您有两个表 A(a,b) 和 B(b,c),那么在加入后以 (a,b,c) 的形式生成结果

Select *
    from A JOIN B USING(b);

将给出三列的结果集(a,b,c)

注意:由于我不知道我们是否可以在 Using 中使用多个参数,因此我将其作为子查询。

于 2015-05-11T18:02:44.797 回答
1

您没有得到重复的列,您真正得到的是表 Family(即 Family.Supervisor_ID)中的 Supervisor_ID 列和表 Supervisor 中的 Supervisor_ID(即 Supervisor.Supervisor_ID),但对于您的结果集,您将两者都视为 Supervisor_ID ,这就是为什么你认为它们是重复的。Center_iD 也会发生同样的情况。

解决方案是从每个表中指定您需要的字段,并决定是否需要获取 Supervisor_ID 和 Center_ID 以及从哪个表中获取。

于 2012-12-17T04:36:09.653 回答
0

据奥利利说,

寻找解释计划
您可以从 y 内部连接中执行 _select x .... 其中 w=z ... 这只是一个示例

于 2012-12-17T04:38:44.000 回答