DB2纯SQL存储过程入门实践

本文介绍了一种在DB2环境下创建纯SQL存储过程的方法。通过建立临时表并进行多层嵌套循环查询,最终返回一个结果集游标。此过程适用于BIRT应用,可在命令行或开发工具中调用。
DB2纯SQL存储过程入门实践


背景:本人现在在DB2 9.1做Birt应用,需用写纯SQL的存储过程,经过多层嵌套循环查询多个表,并返回一个最终的结果集(打开的游标)。然后再在birt中直接调用以下就获取了结果集的纪录,并展示在页面中。为此,我在网上搜索了很多资料,但是没有一个完整的可以执行的DB2存储过程。研究好久了,终于写出来了一个模板性的示例出来。现在拿出来,和各位网友共同分享交流。

示例说明:先创建一个临时表,并插入数据,然后查询临时表,返回游标。

create procedure testPrc()
-- 返回一个纪录
dynamic result sets 1
------------------------------------------------------------------------
-- sql 存储过程
------------------------------------------------------------------------
p1: begin
-- 定义一个全局临时表tmp_hy
declare global temporary table session.tmp_hy
(
dm varchar(10),
mc varchar(10)
)
with replace -- 如果存在此临时表,则替换
not logged; -- 不在日志里纪录
-- 给临时表插入三条数据
insert into session.tmp_hy values('1','1');
insert into session.tmp_hy values('1','1');
insert into session.tmp_hy values('1','1');

p2: begin
-- 声明游标
declare cursor1 cursor with return for
select * from session.tmp_hy;
-- 游标对客户机应用程序保持打开
open cursor1;

end p2;
end p1

另:鉴于有人问到此例子怎么执行,我是在集成开发环境里执行的.运行存储过程的方法很多,可以存在高级编程语言里调用,也可以在命令行调用,也可以在sql开发工具里调用,没法一概而论,还有,这个游标,你要看到结果,需要逐条取出所有纪录.这些都是其它方面的知识,你可以去别的地方补充.我这里怎么运行的,以及怎么处理的,为了避免误导读者,我还是不说了.下面我给出我调用此存储过程得出的结果,如下图:
[url]http://blog.51cto.com/attachment/200612/1166756483234.png[/url]


总结:这个例子很简单,但是很实用,可以作为一个存储过程的模板来用。完全操作的是临时表,你在任何db2数据库下都可以执行,并查看结果。为了保持例子的简洁易懂,我没有设置输入输出参数,这些参数和Oracle里,高级变成语言中函数的参数差不多,所以就写了这个不带参数的。

题外话:DB2 的存储过程和函数与Oracle的差别太大,DB2存储过程允许返回值,还可以设定返回值的数量,而Oracle的存储过程是不允许返回值的;DB2的函数也可以返回值,也可以返回表,而Oracle返回比较随意。用DB2做开发是件很痛苦的事情,原因是没有很好的开发工具,不像Oracle有 PL/SQL这样强大的开发工具可用,但是DB2的性能比Oracle的好,海量T级别的数据库尤为明显。目前我用的是Quest Central For DB2 4.3,功能很弱,连自动弹出表的列名功能都没有!DB2自带的开发中心更烂,没法用,shit!严重与IBM的品牌不相符合。不知道各位网友你们都在用什么开发工具呢?
内容概要:本文系统梳理了多个科研领域的前沿研究与技术实现,重点涵盖FDTD方法中的完美匹配层(PML)研究,以及Matlab/Simulink在电磁、电力、控制、通信、信号处理、图像处理、路径规划、能源系统优化等领域的仿真与算法实现。文中列举了大量基于Matlab和Python的科研案例,如风电功率预测、负荷预测、无人机三维路径规划、电池系统故障诊断、雷达模拟、通信编码、微电网优化调度等,并强调结合智能优化算法(如粒子群、遗传算法、深度学习等)提升系统性能。同时,提供了丰富的代码资源与仿真模型,涵盖永磁同步电机控制、逆变器设计、多智能体任务分配、虚拟电厂调度等复杂系统,助力科研人员快速开展复现实验与创新研究。; 适合人群:具备一定编程基础,熟悉Matlab/Python工具,从事电气工程、自动化、通信、人工智能、新能源、控制科学等相关领域研究的研发人员及研究生。; 使用场景及目标:① 学习并实现FDTD仿真中的PML边界条件以有效抑制数值反射;② 掌握Matlab/Simulink在多物理场建模、控制系统设计与优化算法中的综合应用;③ 借助提供的代码资源完成科研复现、课程设计、竞赛项目或工程原型开发; 阅读建议:此资源以科研实战为导向,不仅提供理论方法,更强调代码实现与仿真验证。建议读者结合自身研究方向,按目录顺序查阅相关模块,下载配套代码进行调试与二次开发,以达到学以致用、融会贯通的目的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值