Mysql查询将2个表中的列获取到一个结果集中

标签 mysql sql join union

我正在尝试创建一个查询,显示 TableA 中的 a4、a2、a3 和日期 TableC 对于通过 b.b1 = 2 连接的所有项目。输出应为 按日期降序排列。

TableA                 
___________________________________________
| a1   | a2   | a3   | a4   | a5   | a6   |
-------------------------------------------
| 1    |  222 | 333  | 444  | 555  | 665  |
-------------------------------------------
| 2    |  asd | sdf  | ert  | jkl  | xcv  |
-------------------------------------------
| 3    |  111 | tyu  | bnm  | abc  | xyz  |
-------------------------------------------
| 4    |  222 | yyy  | dfd  | hgg  | 544  |
-------------------------------------------  
| 5    |  222 | y56  | df5  | hg7  | 234  |
------------------------------------------- 

TableB
___________________
| b1  | b2  | b3  |
-------------------
| 1   | 717 | c   |
------------------- 
| 2   | 727 | d   |
------------------- 
| 3   | 737 | c   |
------------------- 
| 4   | 747 | d   |
------------------- 

TableC - c2 is foreign key to a.a1 - c3 is foreign key to b.b1
_____________________________
| c1  | c2  | c3  |  date   |
-----------------------------
| 1   | 2   | 2   |12-01-12 | 
-----------------------------
| 2   | 1   | 1   |12-05-12 | 
-----------------------------
| 3   | 5   | 2   |12-07-12 | 
-----------------------------
| 4   | 3   | 1   |12-14-12 | 
-----------------------------
| 5   | 4   | 2   |12-18-12 | 
-----------------------------

它应该看起来像这样......

____________________________
| a4  | a2  | a3  |  date  |
----------------------------
| ert | 222 | 333 |12-01-12| 
----------------------------
| df5 | 222 | y56 |12-07-12| 
----------------------------
| dfd | 222 | yyy |12-18-12| 
----------------------------

我得到的结论是,如果我将查询分成两部分,我会从两个表和“UNION ALL”中获取信息 让我的日期在表格底部添加行(还有我不想要的另外两列,c2 和 c1),我实际上想要一列 在我的结果中 a3 旁边称为日期。如何将“日期”列放入结果集中?

SELECT a.a4, a.a2, a.a3
FROM TableA a
JOIN TableC c ON c.c2 = a.a1
JOIN TableB b ON b.b1 = c.c3 and c.c3 = 2
UNION ALL
SELECT d.date,d.c2,d.c1 
From TableC d
JOIN TableB b ON b.b1 = d.c3 and d.c3 = 2

请提出任何您需要的问题,这简直要了我的命。

最佳答案

这里还有其他令人困惑的项目,但无需深入挖掘,这很简单:

SELECT a.a4, a.a2, a.a3, c.date
FROM TableA a
JOIN TableC c ON c.c2 = a.a1
JOIN TableB b ON b.b1 = c.c3 and c.c3 = 2

UNION 并没有做你想象的那样。

还有b表需要join吗?

SELECT a.a4, a.a2, a.a3, c.date
FROM TableA a
JOIN TableC c ON c.c2 = a.a1 and c.c3 = 2

关于Mysql查询将2个表中的列获取到一个结果集中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14863318/

相关文章:

javascript - 如何将 JSON 数据插入父子表

sql - 如何在 SQL Server Management Studio 中获取 "real"CSV 格式的导出输出?

mysql - 根据主表中列的值连接表

mysql更新并设置当前行最后8小时的总和值

php - 如何使用简单的 HTML Dom 从 For 循环将数据作为单个查询插入 MYSQL 数据库

sql - 带有两个表的价格匹配的 Postgres 查询问题

sql - 对有条件的连接行进行计数时出现问题

join - 谷歌 BigQuery : prefix for all columns of joined table with duplicated names

c# - MySQL ODBC参数问题

php - 来自不同表的 MySQLi 匹配 ID