求问各路大神!!!!!!!!

Lishyer 2017-09-22 05:15:03
下面是我写的一段存储过程 是指每隔一段时间就要对op_m_test1表进行更新,写完可以通过,但是扩展性差,现在是只有5条数据,以后可能要上百条数据,有什么办法可以对其改善吗



create or replace procedure pro_op_m_test
as
tab1 dw2.dw2_etl_com@bi52%rowtype;
tab2 dw2.dw2_etl_com@bi52%rowtype;
tab3 dw2.dw2_etl_com@bi52%rowtype;
tab4 Itf2.Inter_Cfg@bi52%rowtype;
tab5 ST.BI_JOB_LIST@FJBIJS_ST%rowtype;
op_tab1 op_m_test1%rowtype;
op_tab2 op_m_test1%rowtype;
op_tab3 op_m_test1%rowtype;
op_tab4 op_m_test1%rowtype;
op_tab5 op_m_test1%rowtype;
begin
select * into op_tab1 from op_m_test1 where table_name='DW_SRV_4GCUUSER_DT';
select * into op_tab2 from op_m_test1 where table_name='DW_IS_MVUSER_DI';
select * into op_tab3 from op_m_test1 where table_name='DW_IS_ALUSER_DI';
select * into op_tab4 from op_m_test1 where table_name='ODS_2IMSG_MSGJH';
select * into op_tab5 from op_m_test1 where table_name='CELL_INFO';
select * into tab1
from dw2.dw2_etl_com@bi52 t where t.tablename='DW_SRV_4GCUUSER_DT';
select * into tab2
from dw2.dw2_etl_com@bi52 t where t.tablename='DW_IS_MVUSER_DI';
select * into tab3
from dw2.dw2_etl_com@bi52 t where t.tablename='DW_IS_ALUSER_DI';
select * into tab4
from Itf2.Inter_Cfg@bi52 T WHERE T.TABLENAME='ODS_2IMSG_MSGJH';
select * into tab5
from ST.BI_JOB_LIST@FJBIJS_ST T WHERE T.ITFDATE='20170911' AND SRCTABLEname='CELL_INFO';
if op_tab1.datafile_day=to_char(sysdate,'yyyymmdd')-1 and op_tab1.status=0 then
dbms_output.put_line('no update');
else
update op_m_test1 set stop_time=tab1.stoptime,
datafile_day=tab1.optime,
status=tab1.status,
status_name=(case tab1.status
when 0 then '加载成功'
when 1 then '正在抽取'
when -1 then '执行失败'
end)
where table_name='DW_SRV_4GCUUSER_DT';
insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name='DW_SRV_4GCUUSER_DT';
end if;
if op_tab2.datafile_day=to_char(sysdate,'yyyymmdd')-1 and op_tab2.status=0 then
dbms_output.put_line('no update');
else
dbms_output.put_line('this');
update op_m_test1 set stop_time=tab2.stoptime,
datafile_day=tab2.optime,
status=tab2.status,
status_name=(case tab2.status
when 0 then '加载成功'
when 1 then '正在抽取'
when -1 then '执行失败'
end)
where table_name='DW_IS_MVUSER_DI';
insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name='DW_IS_MVUSER_DI';
end if;
if op_tab3.datafile_day=to_char(sysdate,'yyyymmdd')-1 and op_tab3.status=0 then
dbms_output.put_line('no update');
else
update op_m_test1 set stop_time=tab3.stoptime,
datafile_day=tab3.optime,
status=tab3.status,
status_name=(case tab3.status
when 0 then '加载成功'
when 1 then '正在抽取'
when -1 then '执行失败'
end)
where table_name='DW_IS_ALUSER_DI';
insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name='DW_IS_ALUSER_DI';
end if;
if op_tab4.datafile_day=to_char(sysdate,'yyyymmdd')-1 and op_tab4.status=0 then
dbms_output.put_line('no update');
else
update op_m_test1 set stop_time=tab4.endtime,
datafile_day=tab4.itfdate,
status=tab4.loadyn,
status_name=(case tab4.loadyn
when 0 then '加载成功'
when 1 then '正在抽取'
when -1 then '执行失败'
end)
where table_name='ODS_2IMSG_MSGJH';
insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name='ODS_2IMSG_MSGJH';
end if;
if op_tab5.datafile_day=to_char(sysdate,'yyyymmdd')-1 and op_tab5.status=0 then
dbms_output.put_line('no update');
else
update op_m_test1 set stop_time=tab5.endtime,
datafile_day=tab5.itfdate,
status=tab5.status,
status_name=(case tab5.status
when 0 then '加载成功'
when 1 then '正在抽取'
when -1 then '执行失败'
end)
where table_name='CELL_INFO';
insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name='CELL_INFO';
end if;
commit;
end pro_op_m_test;


...全文
713 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
碧水幽幽泉 2017-09-23
  • 打赏
  • 举报
回复
以后如何要扩展的话,改起来也非常方便。 只要把

select table_name,datafile_day,status
from op_m_test1 
  where table_name in ('DW_SRV_4GCUUSER_DT','DW_IS_MVUSER_DI','DW_IS_ALUSER_DI','ODS_2IMSG_MSGJH','CELL_INFO')
改成:

select table_name,datafile_day,status
from op_m_test1 
  where table_name in (关于table_name的子查询)
碧水幽幽泉 2017-09-23
  • 打赏
  • 举报
回复
你的存储过程可以优化如下:

create or replace procedure pro_op_m_test
as 
begin  
   for rec in(select table_name,datafile_day,status
                from op_m_test1 
			   where table_name in ('DW_SRV_4GCUUSER_DT','DW_IS_MVUSER_DI','DW_IS_ALUSER_DI','ODS_2IMSG_MSGJH','CELL_INFO')
			 ) loop
	   if (rec.datafile_day = to_char(trunc(sysdate-1),'yyyymmdd') and rec.status = 0 then 
		  dbms_output.put_line('no update');
		
	   else 
		   update op_m_test1 
			  set (stop_time,optime,status,status_name) = (select stop_time,optime,status,
																  decode(status,0,'加载成功',1,'正在抽取','执行失败') status_name
															 from dw2.dw2_etl_com@bi52
															where table_name = rec.table_name
														   )
		   where exists (select null from dw2.dw2_etl_com@bi52 where table_name = rec.table_name);
		   
		   insert into op_m_h_test select table_name,datafile_day,status,status_name,sysdate from op_m_test1 where table_name = rec.table_name;
		end if;
   end loop;
   
   commit;

end pro_op_m_test;
Lishyer 2017-09-22
  • 打赏
  • 举报
回复
op_m_test1的数据内容是根据3张不同的表 抽取出的数据 每天根据这3张表对op_m_test1进行更新
内容概要:本文围绕“阶梯碳下考虑P2G-CCS与供需灵活响应的IES优化调度”展开,基于Matlab平台构建综合能源系统(IES)在阶梯式碳交易机制下的优化调度模型。研究深度融合电制气(P2G)与碳捕集、利用与封存(CCS)技术,结合需求侧灵活响应机制,旨在提升系统的低碳运行能力与经济性。通过建立多能流耦合的优化模型,协调电力、天然气、热力等多种能源形式的协同调度,有效降低系统碳排放强度,并借助YALIMIP工具包调用求解器进行高效求解。文档提供了完整的代码实现、模型构建流程与结果分析方法,涵盖从问题建模到仿真实现的全过程,具备较强的可复现性与科研参考价值。; 适合人群:具备电力系统、能源系统或优化建模相关背景的研究生、高校教师及工程技术人员,尤其适合从事综合能源系统、碳减排策略、P2G与CCS技术集成研究的专业人员,需熟练掌握Matlab编程与基本的数学规划知识。; 使用场景及目标:①用于研究阶梯式碳交易政策下综合能源系统的低碳经济调度策略;②支撑P2G-CCS技术与需求响应机制在IES中的仿真集成与性能评估;③作为撰写高水平学术论文(如EI/SCI收录)的技术基础与复现资源,推动碳中和背景下能源系统优化方向的创新研究。; 阅读建议:建议结合百度网盘提供的完整代码与资料包,按照模块逐步调试程序,重点理解目标函数的设计逻辑、碳交易成本的建模方式、约束条件的数学表达及求解器的配置方法,同时关注多能耦合设备的建模细节,配合公众号“荔枝科研社”获取持续的技术支持与案例拓展。
内容概要:本文系统研究了基于卷积神经网络(CNN)与支持向量机(SVM)融合的CNN-SVM混合模型在数据分类预测中的应用,尤其聚焦于工业故障识别领域。通过Matlab平台实现,该方法首先利用CNN强大的多层次特征提取能力对原始输入数据进行深度特征学习,自动捕获关键局部模式与空间结构信息,随后将提取的高层特征作为输入传递至SVM分类器,借助SVM在高维空间中小样本条件下卓越的分类性能与泛化能力完成最终判别任务。文中详尽阐述了模型的整体架构设计、网络参数配置、训练优化流程及特征迁移机制,充分结合了深度学习在特征表达上的优势与传统机器学习在分类决策上的稳健性。实验部分通过实际故障数据集验证了该混合模型相较于单一CNN或SVM模型在分类准确率、鲁棒性和抗过拟合能力方面的显著提升,证明了其在复杂故障诊断任务中的有效性与先进性; 适合人群:具备一定机器学习与深度学习理论基础,熟悉Matlab编程环境,从事故障诊断、模式识别、智能制造、电力系统监控或工业数据分析等相关领域的研究生、科研人员及工程技术开发者; 使用场景及目标:① 应用于旋转机械、电力设备、航空航天等领域的多类别故障识别与状态监测;② 掌握深度特征提取与传统分类器融合的技术路径,提升小样本、高噪声环境下数据分类的精度与可靠性;③ 为撰写高水平学术论文、开展科研项目或工程实践提供可复现的算法框架与完整代码支持; 阅读建议:读者应深入理解CNN与SVM的协同工作机制,重点分析特征提取层与分类层之间的接口设计,建议动手运行并调试所提供的Matlab代码,尝试在不同数据集上进行迁移实验与参数调优,以全面掌握该混合模型的应用技巧与优化策略。

17,134

社区成员

发帖
与我相关
我的任务
社区描述
Oracle开发相关技术讨论
社区管理员
  • 开发
  • Lucifer三思而后行
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧