我想知道你是否可以在不需要创建新列的情况下将列添加到临时表中
让我们假设以下表格
Table1 | Table2 | Table3 |
Id Atype | Id Btype | Id Ctype |
1 A1 | 1 B1 | 1 C1 |
2 A2 | 2 B2 | 2 C2 |
3 A3 | 3 B3 | 3 C3 |
首先我想创建一个临时表:
CREATE TEMPORARY TABLE IF NOT EXISTS
temp_table ( INDEX(id) )
AS (
SELECT t1.id, t1.atype , t2.btype
FROM table1 t1
left join table2 t2 on t1.id = t2.id);
Result:
temp_table
Id Atype Btype
1 A1 B1
2 A2 B2
3 A3 B3
然后我想在临时表中添加Ctype。 我怎样才能做到这一点? 我可以加入当前临时表还是必须创建一个新的临时表?
我看到的最终结果是1个临时表,如下所示:
Id Atype Btype Ctype
1 A1 B1 C1
2 A2 B2 C2
3 A3 B3 C3
答案 0 :(得分:1)
你不能只使用另一个join
吗?
SELECT t1.id, t1.atype, t2.btype, t3.ctype
FROM table1 t1 LEFT JOIN
table2 t2
ON t1.id = t2.id LEFT JOIN
table3 t3
ON t1.id = t3.id
如果您确实想要修改现有表,那么:
alter table temp_table add ctype varchar(255);
update temp_table tt join
table3 t3
on tt.id = t3.id
set tt.ctype = t3.ctype;
答案 1 :(得分:0)
您可以在创建第3个join()
的插件时执行此操作 CREATE TEMPORARY TABLE IF NOT EXISTS
temp_table ( INDEX(id) )
AS (
SELECT t1.id, t1.atype , t2.btype, t3.Ctype
FROM table1 t1
left join table2 t2 on t1.id = t2.id
left join table3 t3 on t1.id = t3.id);