PRO*C 函数事例 3 -- 游标使用

1、Oracle中的游标
    Oracle使用两种游标: 显式游标和隐式游标. 不管语句返回多少条记录, Oracle为每条使用的SQL语句隐式地定义一个游标. Oracle为每个DELETE ,
UPDATE, INSERT 等SQL命令隐式地声明游标. 用户声明并使用显式游标处理SELECT语句返回的多条记录.
    游标是ORACLE和PRO*C存放查询结果的工作区域。一个游标(已命名的)与一条SELECT语句相关联。操作游标有由4条命令:
(1)DECLARE CURSOR;(2)OPEN CURSOR;(3)FETCH;(4)CLOSE CURSOR。
A. 定义游标
        一个游标必须首先定义, 才能使用它。语法为:
        EXEC SQL DECLARE 〈游标名〉CORSOR FOR
        SELECT 〈列〉
        FROM 〈表〉
        例如:
        EXEC SQL DECLARE CSOR, CURSOR FOR
        SELECT ENAME , JOB, SAL
        FROM EMP
        WHERE DEPTNO=:DEPTNO;
        当赋给一个与查询相关联的游标CURSOR之后, 当SELECT查询EMP时可从
        数据库中返回多行,这些行就是CURSOR的一个活动区域。
        注意:
        1) 定义游标必须在对游标操作之前完成;
        2) PRO*C不能引用没有定义的游标;
        3) 游标定义后,其作用范围是整个程序。所以对一个程序来讲, 同时定义两个相同的游标是错误的。
B. 申请游标
        在定义游标之后, 应用程序在使用游标变量之前, 必须首先调用ALLOCATE语句
        申请游标, 也就是为游标变量分配内存区域, ALLOCATE 语法格式为:
        EXEC SQL ALLOCATE :cursor_variable;
        C. 打开游标
        打开游标的OPEN语句主要用来输入主变量的内容,这些主要是WHERE中使用
        的主变量。打开游标的语句是:EXEC SQL OPEN 〈游标名〉
        当打开游标后,可以从相关的查询中取出多于一行的结果。所有满足查询标准的
        行组成一集合,叫做“游标活动集”。通过取操作,活动集中的每一行或每一组是一
        个一个返回的,查询完成后, 游标就可关闭了。如图所示:
        
        注意:1)游标处于活动集的第一行前面;
                    2)若改变了输入主变量就必须重新打开游标。
D. 取数据
        从活动集中取出一行或一组把结果送到输出主变量中的过程叫取数据。输出主变量
        的定义在取数据语句中。取数据的语句如下:
        EXEC SQL FETCH〈游标名〉INTO:主变量1,主变量2,……
        FETCH的工作过程如图所示:
        
        如图所示的查询结果指满足查询条件的查询结果。使用FETCH应注意以下几点:
        <1> 游标必须先定义再打开。
        <2> 只有在游标打开之后才能取数据,即执行FETCH语句。
        <3> FETCH语句每执行一次,从当前行或当前组取数据一次,下一行或下一组向上移一次。游标每次所指的行或组都为当前行或当前组,而FETCH
                每次都是取游标所指定的行或组的数据。
        <4> 当游标活动集空之后,ORCLE返回一个SQLCA。SQLCA(=1403)。
        <5> 若希望此游标再操作, 必须先关闭再打开它。
        <6> 在C程序中可以开辟一个内存空间,来存放操作结果,这样就能利用开辟的空间来灵活操纵查询的结果。
E.关闭游标
        取完活动集中所有行后,必须关闭游标,以释放与该游标有关的资源。
        关闭游标的格式为:
        EXEC SQL CLOSE 游标名;
        例如:
        EXEC SQL CLOSE C1;
        ORACLE V5.0版支持SQL格式“CURRENT OF CURSOR”。这条语句将指向一个
        游标中最新取出的行, 以用于修改和删除操作。该语句必须有取操作之后使用,
        它等同存储一个ROWID,并使用它。
F. 释放游标
        CLOSE语句在关闭游标变量时, 并未释放游标变量所点用的内存. 所以, 以游标变
        量关闭之后应用程序可以重新打开游标变量, 实现各种游标操作. 需要关闭游标变
        量并释放经所点用的内存. 方法如下:
        EXEC SQL FREE :cursor_name;
        
2、函数事例:

int DbsTblLineList (int nOpr)
{
    int   nList;
    int   i;                                                                                               

    EXEC SQL DECLARE tbl_line_cfg_cur CURSOR FOR
        SELECT GATE_ID, LINE_IP, LINE_PORT
        FROM  TBL_LINE_CFG ORDER BY GATE_ID;                                                               

    EXEC SQL OPEN tbl_line_cfg_cur;
    if (sqlca.sqlcode != 0)
    {
        printf (ERROR , "error code [%d], reason[%s] \n",  sqlca.sqlcode, ( char * )sqlca.sqlerrm.sqlerrmc);

        return -1;
    }                                                                                                      

    i = 0;
    nList = 1;                                                                                             

    while (1)
    {
        /***********************
        * 从库表中FETCH数据,查询
        ************************/
        memset (saGateId, 0x00, sizeof(saGateId));
        memset (saLineIp, 0x00, sizeof(saLineIp));
        naLinePort = 0;                                                               

        EXEC SQL FETCH tbl_line_cfg_cur INTO
            :saGateId, :saLineIp, :naLinePort;
        if (sqlca.sqlcode != 0 && sqlca.sqlcode != 1403)
        {
            printf ("fetch tbl_line_cfg_cur error sqlcode[%d]", sqlca.sqlcode);
            EXEC SQL CLOSE tbl_line_cfg_cur;                                          

            return -1;
        }
        if (sqlca.sqlcode == 1403)
        {
            EXEC SQL CLOSE tbl_line_cfg_cur;                                          

            i++;
            lGateList[i].nList = -1;                                                  

            break;
        } 

        lGateList[i].nList = nList;
        memcpy (lGateList[i].saGateId, saGateId, 2);
        memcpy (lGateList[i].saLineIp, saLineIp, 40);
        trimspace (lGateList[i].saLineIp);
        lGateList[i].naLinePort = naLinePort;        

        i++;
        nList++;
    }                                                

    return 0;
}
时间: 2024-11-10 16:54:19

PRO*C 函数事例 3 -- 游标使用的相关文章

PRO*C 函数事例 2 -- 数据库操作

Pro*C Oracle 的嵌入式开发,数据库处理部分最好能提取到一个模块,按照对不同数据库表的操作分成不同的.pc文件(如 DbsInstStat.pc).将此模块编译成库(c文件编译时链接此库),.c文件处理库表时调用对应数据库模块(.pc)中的函数即可.      函数事例: DbsDef.h #define DBS_INIT 0 #define DBS_SELECT 1 #define DBS_LOCK 2 #define DBS_UPDATE 3 #define DBS_DELETE

PRO*C 函数事例 1 -- 数据库连接、事务处理

1.程序结构        每一个Pro*C程序都包括两部分:(1)应用程序首部:(2)应用程序体        应用程序首部定义了ORACLE数据库的有关变量, 为在C语言中操纵ORACLE数据库做好了准备.应用程序体基本上由Pro*C的SQL语句调用组成.主要指查询SELECT.INSERT.UPDATE.DELETE等语句.        应用程序的组成结构如图所示:       2.函数事例 EXEC SQL INCLUDE sqlca ; #include "my_sys.h"

使用IDA PRO+OllyDbg+PEview 追踪windows API 动态链接库函数的调用过程

http://bbs.pediy.com/showthread.php?p=1354999 标 题: [原创]使用IDA PRO+OllyDbg+PEview 追踪windows API 动态链接库函数的调用过程.作 者: shayi时 间: 2015-02-12,05:19:54链 接: http://bbs.pediy.com/showthread.php?t=197829 使用IDA PRO+OllyDbg+PEview 追踪windows API 动态链接库函数的调用过程. (本文同步更

MySQL中的存储过程和函数使用详解

一.对待存储过程和函数的态度 在实际项目中应该尽量少用存储过程和函数,理由如下: 1.移植性差,在MySQL中的存储过程移植到sqlsever上就不一定可以用了. 2.调试麻烦,在db中报一个错误和在应用层报一个错误不是一个概念,那将是毁灭性打击,直接一个error:1045什么的更本毫无头绪. 3.扩展性不高. 所以在互联网时代大型项目应该尽量少使用(不使用)存储过程和函数. 二.创建存储过程 2.1什么是存储过程? 存储过程和存储函数都是一组sql语句的集合.这些语句集合被当做一个整体存入数

plsql存储过程和函数

8. 存储子程序(命名块) 存储子程序下面三种:(1) 存储过程:store procedure(SP)(2) 函数:function(FUN)(3) 包和包体:package/package body(PKG) 存储过程:oracle的一种对象v_sqlcodeA 在一个用户下有唯一的名字B 存储在数据库中C 可以接收传入参数并且有多个返回值D 可以直接执行和在其他程序中调用E 不可以被select语句调用 函数:oracle的一种对象A 在一个用户下有唯一的名字B 存储在数据库中C 可以接收

python使用游标访问数据

游标是一种数据访问对象,可用于在表中迭代一组行或者向表中插入新行.游标有三种形式:搜索.插入或更新.游标通常用于读取现有几何和写入新几何. 每种类型的游标均由对应的 ArcPy 函数(SearchCursor.InsertCursor 或 UpdateCursor)在表.表格视图.要素类或要素图层上创建.搜索游标可用于检索行.更新游标可用于根据位置更新和删除行,而插入游标可用于向表或要素类中插入行. 游标 说明 InsertCursor(dataset, {spatial_reference})

SQL函数说明大全

一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描述. 函数类别 作用 聚合函数 执行的操作是将多个值合并为一个值.例如 COUNT.SUM.MIN 和 MAX. 配置函数 是一种标量函数,可返回有关配置设置的信息. 转换函数 将值从一种数据类型转换为另一种. 加密函数 支持加密.解密.数字签名和数字签名验证. 游标函数 返回有关游标状态的信息.

第十一章 存储过程和函数

第一节:存储过程和函数的引入 存储过程和函数是在数据库中定义一些 SQL 语句的集合,然后直接调用这些存储过程和函数来执行已经定义好的 SQL 语句. 存储过程和函数可以避免开发人员重复的编写相同的 SQL 语句. 而且, 存储过程和函数是在 MySQL服务器中存储和执行的,可以减少客户端和服务器端的数据传输: 第二节:创建存储过程和函数 2.1 创建存储过程 CREATE PROCEDURE sp_name([proc_parameter[,...]])[characteristic...]

Duang!危险的oracle游标

1.引言 SQL是面向集合的语言,其结果一般是集合量(含多条记录),而pl/sql的变量是标量,一组变量一次只能存放一条记录.很多时候查询结果的记录数是不确定的,无法提前声明足够的变量.于是引入了游标的概念,游标使得数据库操作更灵活,但同时也给黑客入侵数据库带来了机会.安华金和数据库安全实验室(DBSec Labs)基于游标的应用原理,本文讨论游标可能带来什么安全隐患以及如何应对这些安全隐患. 2.游标的分类 oracle数据库游标是Pl/sql执行DQL.DML等语句的时候,oracle在内存