首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > 如何在Oracle中使用游标来实现多重循环
【标  题】:如何在Oracle中使用游标来实现多重循环
【关键字】:c,Oracle,Oracle
【来  源】:网络

如何在Oracle中使用游标来实现多重循环


 
这篇文章,是最近在写一个项目中所用的存储过程,由于是第一次接触oracle,其间花费了许多功夫,才把功能实现!特记录下来,以供参考!
[color=blue]create or replace package PSH_GPRSSTREAMSTAT is[/color]
[color=red]
-- Author : ADMINISTRATOR
-- Created : 2004-12-8 10:56:01
-- Purpose : GPRS流量统计状态
-- 统计GPRS流量
[/color]
type
C_Cur is ref cursor;
function Calcu_GPRSSTREAM return number;
end PSH_GPRSSTREAMSTAT;
-----------------------------------------------------------------------------
create or replace package body PSH_GPRSSTREAMSTAT is
function Calcu_GPRSSTREAM return number
is
c_IPPackHeadLen constant number := 40; -- 定义IP包头长度
CURSOR c_SPINFO is
select distinct spid from sh_spinfo where isactive = '0';

c_MDTINFO C_Cur ;
v_MDTINFO number;

v_UpTransContentLens number(20,0); -- 存放当前GPRS终端上传转发的信息内容长度
v_UpContentLens number(20,0);
v_UpTotalLens number(20,0); -- 累计GPRS终端上传的信息内容长度
v_DownContentLens number(20,0);
v_DownTotalLens number(20,0);
newID number(20,0);

begin
-- 初始化
select max(statid) into newID from sh_gprsstreamstat;
if (newID is null) then
newID := 1;
end if;

for v_SPINFO In c_SPINFO loop -- 首先获取SPID
-- 其次遍历出与当前SPID对应的所有MDT
open c_MDTINFo for select distinct mdtid from sh_mdtinfo where (isactive = '0') and (spid = v_SPINFO.spid);
loop
fetch c_MDTINFO into v_MDTINFO;
exit when c_MDTINFO%notfound;

v_UpContentLens := 0;
v_UpTransContentLens := 0;
v_UpTotalLens := 0;
v_DownContentLens := 0;
v_DownTotalLens := 0;
-- 下面两个select语句是用来获得GPRS终端上传的信息流量
select sum(length(content) + c_IPPackHeadLen) into v_UpContentLens from sh_gprsmdtupinfo where (MDTID = v_MDTINFO) and (spid = v_SPINFO.spid) ;
select sum(length(content) + c_IPPackHeadLen) into v_UpTransContentLens from sh_gprsmdttransinfo where (issuccess = '1') and (MDTID = v_MDTINFO) and (spid = v_SPINFO.spid) ;
if (v_UpContentLens is null) then
v_UpContentLens := 0;
end if;
if (v_UpTransContentLens is null) then
v_UpTransContentLens := 0;
end if;
v_UpTotalLens := v_UpTotalLens + v_UpContentLens + v_UpTransContentLens;

-- 下面的Select语句是用来获得服务商下发的信息流量
select sum(length(content) + c_IPPackHeadLen) into v_DownContentLens from sh_gprsspdowninfo where (MDTID = v_MDTINFO) and (spid = v_SPINFO.spid) ;
if (v_DownContentLens is null) then
v_DownContentLens := 0;
end if;
v_DownTotalLens := v_DownTotalLens + v_DownContentLens ;

-- 将统计出的累计值存放到流量状态统计表中
if (v_UpTotalLens >0) or (v_DownTotalLens > 0) then
insert into sh_gprsstreamstat (statid,spid,mdtid,starttime,endtime,mdtupstream,spdownstream)
values(newID,v_SPINFO.spid,v_MDTINFO,sysdate,sysdate,v_UpTotalLens,v_DownTotalLens);
-- 自增量加1
newID := newID + 1;
end if;
end loop;
close c_MDTINFO;
commit;
end loop;
return 1;
end;

begin
null;
end PSH_GPRSSTREAMSTAT;

利用Oracle数据库存储和分析Unix操作系统的性能:【上一篇】
oracle trunc()函数的用法:【下一篇】
【相关文章】
  • 利用Oracle数据库存储和分析Unix操作系统的性能
  • oracle数据库中插入特殊符号'&'
  • oracle 数据分页查询
  • oracle中的树型查询
  • Ora2html--收集Oracle数据库信息
  • How to Use DBMS_SUPPORT Package
  • Oracle 9iAS配置运行FORM、Report
  • Oracle9i中一个特殊等待事件--null event
  • Oracle 9与Oracle 8中CPU_COSTING有什么变化
  • ORACLE中BFILE字段的使用研究
  • 【随机文章】
  • 为VC6的CHtmlView继承类添加NavigateError事件响应
  • 深入浅出SQL系列教程 第二节  www.sqlzoo.cn网站简介
  • Struts入门初步知识[转载]
  • C++的数据类型转换关键字dynamic_cast
  • 开发第一个J2EE、配置J2EE环境及Cloudscape数据库
  • 锁定表列
  • AIX常见问题整理 (5)
  • 伟大架构师的秘密
  • 交换排序
  • 第五道虎纹:静态引入机制
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.