MySQL - 从另一个表中向临时表添加一列

时间:2018-02-23 12:48:49

标签: mysql sql temp-tables

我想知道你是否可以在不需要创建新列的情况下将列添加到临时表中

让我们假设以下表格

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

2 个答案:

答案 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);