[Oracle]使用非滚动游标

源码:xx.pc
/*
功能:演示了Oracle非滚动游标操作
定义游标时注意事项:
1. DECLARE CURSOR语句必须是使用游标的第一条语句
2. 游标名称是一个标识符,而不是宿主变量,其长度是可以任意的,但只有前31个字符有效
3. 游标所对应的SELECT语句不能包含INTO子句
4. 游标语句(DECLARE,OPEN,FETCH,CLOSE)必须在同一个预编译单元内
*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <sqlca.h>
#pragma comment(lib, "orasql10.lib")
int connect();
void cursor();
void sql_error();
void main()
{
EXEC SQL WHENEVER SQLERROR DO sql_error();	// 安装错误处理句柄
if(connect() == 0)
{
cursor();
EXEC SQL COMMIT RELEASE;
}
else
printf("连接失败\n");
}
int connect()					// connect to oracle database
{
char username[10], password[10], server[10];
strcpy(username, "scott");
strcpy(password, "zzb888888");
strcpy(server, "orcl");
EXEC SQL CONNECT :username IDENTIFIED BY :password USING :server;
if(sqlca.sqlcode == 0)
return 0;
else
return sqlca.sqlcode;
}
void sql_error()				// print error infomation
{
printf("%.*s\n", sqlca.sqlerrm.sqlerrml, sqlca.sqlerrm.sqlerrmc);
}
void cursor()					// 游标操作
{
int dno, eno;				// 定义宿主变量
char name[10];
float salary;
printf("输入部门号:");
scanf("%d", &dno);
EXEC SQL DECLARE emp_cursor CURSOR FOR Select empno, ename, sal from emp where deptno=:dno;	// 定义游标
EXEC SQL OPEN emp_cursor;	// 打开游标
EXEC SQL WHENEVER NOT FOUND DO break;	// 游标数据提取完毕后退出循环
for(; ;)
{
EXEC SQL FETCH emp_cursor into :eno, :name, :salary;	// 循环提取数据
printf("name = %s(%d), salary = %.2f\n", name, strlen(name), salary);
}
EXEC SQL CLOSE emp_cursor;	// 关闭游标
printf("sqlca.sqlerrd[2] = %d\n", sqlca.sqlerrd[2]);		// sqlca.sqlerrd[2]存放着Select语句作用的行数
}

运行结果:

输入部门号:20
name = SMITH    (9), salary = 800.00
name = JONES    (9), salary = 2975.00
name = SCOTT    (9), salary = 3000.00
name = ADAMS    (9), salary = 1100.00
name = FORD     (9), salary = 3000.00
sqlca.sqlerrd[2] = 5

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407711.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Taro+react开发(20)--控制icon大小

<AtIconsize{20}className"company-icon"value"trash"color"#ccc"></AtIcon>

线程访问临界区的问题 实例,需解决

using System; using System.Threading; namespace LockAndThread { /// <summary> /// Class1 的摘要说明。 /// </summary> class Test { /// <summary> /// 应用程序的主入口点。 /// </summary> static Thread[] threadsnew Thread[10]…

[HTML5]移动Web应用程序开发 HTML5篇 (四) 多媒体API

介绍本系列博客将主要介绍如今大红大紫的移动Web应用程序开发最重要的三个工具&#xff1a;HTML5&#xff0c;JavaScript&#xff0c; CSS3。本篇是HTML5介绍的第三篇&#xff0c;主要介绍HTML5的Canvas API。相关文章&#xff1a;移动Web应用程序开发 HTML5篇 (一) HTML5简介移…

Taro+react开发(21)--注意参数格式

constructor() {super(...arguments);this.state {dataList: [],checkedList: [],isOpend: false,code: ""};}

Vue基础之Vue模板语法

插值&#xff1a; 文本&#xff1a; 数据绑定最常见的形式就是使用 “Mustache” 语法&#xff08;双大括号&#xff09;的文本插值&#xff0c;双大括号会将数据解析成纯文本 Mustache 标签将会被替代为对应数据对象上 msg 属性的值。无论何时&#xff0c;绑定的数据对象…

html头部尾部分离组件引入(JQ)

html写官网之类&#xff0c;我们经常会有很多页面同一头部和尾部&#xff0c;我们把它们分离出来&#xff0c;组件引入 vue等框架类的就不说了&#xff0c;主要是说html原生态的 &#xff08;如果是PHP文件可以直接include() 或 require() 函数引入html文件&#xff09; 用到JQ…

[Oracle]使用滚动游标

源代码&#xff1a;xx.pc /*功能&#xff1a;演示了Oracle滚动游标操作定义游标时注意事项&#xff1a;1. DECLARE CURSOR语句必须是使用游标的第一条语句2. 游标名称是一个标识符&#xff0c;而不是宿主变量&#xff0c;其长度是可以任意的&#xff0c;但只有前31个字符有效3…

CMOS密码安全攻略

要说密码。首先就是CMOS密码了。CMOS(本意是指互补金属氧化物半体存储器&#xff0c;是一种大规模应用于集成电路芯片制造的原料)是电脑主板上的一块可读写的RAM芯片&#xff0c;主要用来保存当前系统的硬件配置。CMOS RAM芯片由系统通过一块后备电池供电&#xff0c;所以无论是…

Taro+react开发(22)--模态框组件

<AtModalisOpened{isOpend}title"标题"cancelText"取消"confirmText"确认"onClose{this.handleClose}onCancel{this.handleCancel}onConfirm{this.handleConfirm}content"确认删除吗"/>

JQ trigger触发a标签点击事件

trigger() 方法触发被选元素的指定事件类型。 $("a").trigger(click) ;这样直接触发a标签上的点击事件无法生效 需要绑定给a标签的子集 $("a span").trigger(click) ;jq触发a标签跳转成功

xmpp muc 群聊协议 3

6. Entity Use Cases A MUC implementation MUST support Service Discovery [7]. 服务端必须实现 service discover 6.1 Discovering Component Support for MUC 发现服务器是否支持muc A Jabber entity may wish to discover if a service implements the Multi-User Chat pr…

Vue基础之Class和Style绑定

既然v-bind可以动态绑定标签的属性&#xff0c;那么也可以用v-bind来处理class和style&#xff0c;只需要计算出表达式最终的字符串。不过&#xff0c;字符串拼接麻烦又易错。因此&#xff0c;在 v-bind 用于 class 和 style 时&#xff0c; Vue.js 专门增强了它。表达式的结果…

Pro*c使用滚动游标进行更新或删除游标行

代码&#xff1a;xx.pc /* 功能&#xff1a;演示了Oracle滚动游标进行更新(或删除)操作定义游标时注意事项&#xff1a; 1. DECLARE CURSOR语句必须是使用游标的第一条语句 2. 游标名称是一个标识符&#xff0c;而不是宿主变量&#xff0c;其长度是可以任意的&#xff0c;但只有…

Silverlight学习笔记之使用TranslateTransform控制对象位置

在Canvas中,除了直接使用Canvas.Top与Canvas.Left属性之外,我们可以使用TextBlock.RenderTransform的TranslateTransform的X与Y属性来控制文本显示的位置。代码如下&#xff1a;<TextBlockText"Hello TranslateTransform"Canvas.Left"34" Canvas.Top&qu…

Taro+react开发(23)--componentWillReceiveProps

componentWillReceiveProps# void componentWillReceiveProps(object nextProps ) 当props发生变化时执行&#xff0c;初始化render时不执行&#xff0c; 在这个回调函数里面&#xff0c;你可以根据属性的变化&#xff0c;通过调用this.setState() 来更新你的组件状态&#xff…

MVC Area Usage

ASP.NET MVC Area操作 新建 Area&#xff1a;右键 -> Add –> Area继承 AreaRegistration&#xff0c;重写AreaName属性与RegisterArea方法 public class BookStudyAreaRegistration : AreaRegistration {public override string AreaName{get{return "BookStudy&qu…

[Pro*c]滚动游标变量的使用

代码&#xff1a;xx.pc /* 功能&#xff1a;演示了Oracle滚动游标变量的使用定义游标时注意事项&#xff1a; 1. DECLARE CURSOR语句必须是使用游标的第一条语句 2. 游标名称是一个标识符&#xff0c;而不是宿主变量&#xff0c;其长度是可以任意的&#xff0c;但只有前31个字…

css裁剪clip-path画多边形

clip-path有三种属性 第一种 circle 画圆 clip-path: circle(30%); 30%为半径大小 clip-path: circle(50% at 50% 50%); 后面的50%为圆心位置 第二种 ellipse 椭圆 clip-path: ellipse(32% 43% at 49% 50%); 32%为宽 43%为高 后面两个49%&#xff0c;50%为圆心位置 第三种 p…

教你培养成功的必备因素——强烈的企图心

企图心没有教&#xff0c;但是可以培养&#xff0c;我可以教你如何培养自己的企图心 有一次我上安东罗宾的课程&#xff0c;在夏威夷&#xff0c;安东罗宾的课程有很多世界第一名演讲&#xff0c;分享他们成为冠军的经验。安东罗宾请了一个马拉松选手&#xff0c;这个马拉松不是…

Vue基础之Vue条件渲染

v-if 在 Vue.js &#xff0c;我们使用 v-if 指令实现的功能 也可以用 v-else 添加一个 “else” 块 template-if 因为 v-if 是一个指令&#xff0c;需要将它添加到一个元素上。但是如果我们想切换多个元素呢&#xff1f;此时我们可以把一个<template>元素当做包装…