Mysql SQL insert into select from-插入id而不是数据
我需要用Mysql SQL insert into select from-插入id而不是数据,mysql,sql,oracle,fact-table,Mysql,Sql,Oracle,Fact Table,我需要用lds\u placement表中的数据填充事实表。我已经选择了这些记录,下面是它的样子: fk1_account_id | fk3_job_role_id | salary | no_of_placements | YEAR --------------------------------------------------------------------- 10 | 3 | 165000 | 5
lds\u placement
表中的数据填充事实表。我已经选择了这些记录,下面是它的样子:
fk1_account_id | fk3_job_role_id | salary | no_of_placements | YEAR
---------------------------------------------------------------------
10 | 3 | 165000 | 5 | 2010
10 | 3 | 132000 | 4 | 2011
10 | 3 | 132000 | 4 | 2012
20 | 2 | 990000 | 3 | 2010
20 | 2 | 132000 | 2 | 2011
20 | 2 | 132000 | 2 | 2012
我想将另一个名为time\u dim
的表中的time\u id
插入year
列,而不是实际年份本身
time\u dim
表如下所示:
time_id | year
---------------
5 | 2015
1 | 2013
2 | 2010
3 | 2014
4 | 2012
6 | 2011
我需要在“年”栏中插入的内容实际上是:
year
2
6
4
2
6
4
请告诉我如何在表中插入时间_id
,而不是年份
。
下面是我用来选择最上面的表的代码
SELECT
fk1_account_id,
fk3_job_role_id,
Sum(actual_salary) AS salary,
Count(1) AS no_of_placements,
MAX(EXTRACT(YEAR FROM plt_estimated_end_date)) AS year
FROM lds_placement
GROUP BY fk1_account_id, fk3_job_role_id, EXTRACT(YEAR FROM plt_estimated_end_date)
ORDER BY fk1_account_id;
如果要捕获
年份
在时间维度
中不存在的记录,请使用左联接
。否则请使用内部连接
select t.fk1_account_id,t.fk3_job_role_id,t.salary,t.no_of_placements
,d.time_id
from
(SELECT fk1_account_id, fk3_job_role_id, Sum(actual_salary) as salary, Count(1) as no_of_placements, MAX(EXTRACT(YEAR FROM plt_estimated_end_date)) AS YEAR
FROM lds_placement
GROUP BY fk1_account_id, fk3_job_role_id, EXTRACT(YEAR FROM plt_estimated_end_date)
)t
left join time_dim d
on t.year=d.year
order by t.fk1_account_id
非常感谢你。你消除了我一整天的头痛