将两个选择组合在一起,而不是在另一个之上

时间:2012-04-23 02:25:49

标签: mysql merge

我的MySQL数据库中有这个结构:

   +--------------+    +--------------+
   |    table_1   |    |    table_2   | 
   +----+---------+    +----+---------+  
   | id |   name  |    | id | surname |  
   +----+---------+    +----+---------+  
   | 1  | tbl1_1  |    | 1  | tbl2_1  |  
   | 2  | tbl1_2  |    | 2  | tbl2_2  |   
   | 3  | tbl1_3  |    | 3  | tbl2_3  |  
   +----+---------+    +----+---------+   

我需要一个返回此内容的查询:

   +----+---------+---------+
   | id |   name  | surname |
   +----+---------+---------+
   | 2  | tbl1_2  | tbl2_2  |
   +----+---------+---------+

我在谷歌搜索过,我找到的是UNION这样做:

   +----+---------+
   | id |  name   |
   +----+---------+
   | 2  | tbl1_2  | 
   | 2  | tbl2_3  |
   +----+---------+  

这不是我想要的。我需要它们彼此相邻,而不是相互叠加。

2 个答案:

答案 0 :(得分:0)

您需要根据您的要求使用JOIN,即连接类型。

SELECT id,name,surname FROM table_1 INNER JOIN table_2 on table_2.id=table_1.id WHERE table_1.id = 2

INNER JOIN将选择两个表中的所有行,只要我们匹配的id列之间存在匹配,即两个表中都存在ID

答案 1 :(得分:0)

这是必须做的事情:

SELECT table_1.id, name, surname FROM table_1, table_2 WHERE table_1.id = 2 AND table_2.id = 2