技术开发 频道

混合编程:嵌入式SQL与主语言的通信

  三、游标(cursor)

  游标是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果。每个游标区都有一个名字,用户可以用游标逐一获取记录,并赋给主变量,交由主语言进一步处理。

  为什么要使用游标?

  1、 SQL语言与主语言具有不同数据处理方式。

  2、 SQL语言是面向集合的,一条SQL语句原则上可以产生或处理多条记录。

  3、 主语言是面向记录的,一组主变量一次只能存放一条记录,仅使用主变量并不能完全。

  4、 满足SQL语句向应用程序输出数据的要求。

  5、 嵌入式SQL引入了游标的概念,用来协调这两种不同的处理方式。

  下面用个程序详解:

  #include
  #include
  
EXEC SQL BEGIN DECLARE SECTION; /*主变量说明开始*/
  
char deptname[64];
  
char HSno[64];
  
char HSname[64];
  
char HSsex[64];
  
int HSage;
  
int NEWAGE;
  
long SQLCODE;
  
EXEC SQL END DECLARE SECTION; /*主变量说明结束*/
  
EXEC SQL INCLUDE sqlca; /*定义SQL通信区*/
 
/*************************************************************************/
  
int main(void) /*C语言主程序开始*/
  {
  
int count = 0;
  
char yn; /*变量yn代表yes或no*/
  printf("Please choose the department name(CS
/MA/IS): ");
  scanf("
%s", deptname); /*为主变量deptname赋值*/
  
EXEC SQL CONNECT TO HP-08D6CXF128B\SQL2000 USER sa; /*连接数据库TEST*/
  
EXEC SQL DECLARE SX CURSOR FOR /*定义游标*/
  
SELECT Sno, Sname, Ssex, Sage /*SX对应语句的执行结果*/
  
FROM Student
  
WHERE SDept = :deptname;
  
EXEC SQL OPEN SX; /*打开游标SX便指向查询结果的第一行*/
  
for ( ; ; ) /*用循环结构逐条处理结果集中的记录*/
  {
  
EXEC SQL FETCH SX INTO :HSno, :HSname, :HSsex,:HSage;
  
/*推进游标,将当前数据放入主变量*/
  
if (sqlca->sqlcode != 0) /* sqlcode != 0,表示操作不成功*/
  
break; /*利用SQLCA中的状态信息决定何时退出循环*/
  
if(count++ == 0) /*如果是第一行的话,先打出行头*/
  printf("\n
%-10s %-20s %-10s %-10s\n", "Sno", "Sname", "Ssex", "Sage");
  printf("
%-10s %-20s %-10s %-10d\n", HSno, HSname, HSsex, HSage);
  
/*打印查询结果*/
  printf("
UPDATE AGE(y/n)?"); /*询问用户是否要更新该学生的年龄*/
  do{
  scanf("
%c",&yn);
  }
  
while(yn != 'N' && yn != 'n' && yn != 'Y' && yn != 'y');
  
if (yn == 'y' || yn == 'Y') /*如果选择更新操作*/
  {
  printf("INPUT NEW AGE:");
  scanf("
%d",&NEWAGE); /*用户输入新年龄到主变量中*/
  
EXEC SQL UPDATE Student /*嵌入式SQL*/
  
SET Sage = :NEWAGE
  
WHERE CURRENT OF SX ;
  }
/*对当前游标指向的学生年龄进行更新*/
  }
  
EXEC SQL CLOSE SX; /*关闭游标SX不再和查询结果对应*/
  
EXEC SQL COMMIT WORK; /*提交更新*/
  
EXEC SQL DISCONNECT TEST; /*断开数据库连接*/
  }
0
相关文章