oracle存储过程将表1的数据插入表2,俩张表的结构一样,要用到游标
表的结构如图要求:先取biz_src=‘091000’的并且update_time中时间最新的,如果关联不到party_id的,再取biz_src<>‘091000’的并...
表的结构如图
要求:
先取biz_src=‘091000’的 并且 update_time中时间最新的,如果关联不到party_id的,再取biz_src<>‘091000’的 并且 update_time中时间最新的,party_id是外键。 展开
要求:
先取biz_src=‘091000’的 并且 update_time中时间最新的,如果关联不到party_id的,再取biz_src<>‘091000’的 并且 update_time中时间最新的,party_id是外键。 展开
3个回答
展开全部
create procedure xxx
as
begin
execute immediate
'
insert into table2
select * from (
select * from (
select t.*,row_number() over(partition by t.name order by t.id desc) as order_id from test_insert t
where t.party_id not in (select party_id from &foreign_table)
and biz_src='091000'
)
where t.order_id =1
union all
select * from (
select t.*,row_number() over(partition by t.name order by t.id desc) as order_id from test_insert t
where t.party_id in (select party_id from &foreign_table)
and biz_src<>'091000'
)
where t.order_id =1
)
'
commit;
end;
&foreign_table,你要手动改下关联表的名字,我不知道
as
begin
execute immediate
'
insert into table2
select * from (
select * from (
select t.*,row_number() over(partition by t.name order by t.id desc) as order_id from test_insert t
where t.party_id not in (select party_id from &foreign_table)
and biz_src='091000'
)
where t.order_id =1
union all
select * from (
select t.*,row_number() over(partition by t.name order by t.id desc) as order_id from test_insert t
where t.party_id in (select party_id from &foreign_table)
and biz_src<>'091000'
)
where t.order_id =1
)
'
commit;
end;
&foreign_table,你要手动改下关联表的名字,我不知道
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
推荐楼主学习下merge
更多追问追答
追问
谢谢!但领导要求这样的。。请各位大仙,,帮帮忙吧,这些之前没接触过!
追答
你这2部分关联到的和关联不到的都是插入吗?
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
建议楼主学习一下Merge,给你个链接。
http://blog.csdn.net/nsj820/article/details/5755685
http://blog.csdn.net/nsj820/article/details/5755685
追问
嗯!谢谢!有机会我会学下的。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询