#include <stdio.h>#include <stdlib.h>#include <string.h>#include "util.h"#include <sqlca.h>``EXEC SQL INCLUDE SQLCAmain(){EXEC SQL BEGIN DECLARE SECTIONchar firstname[13]char userid[9]char passwd[19]EXEC SQL END DECLARE SECTIONEXEC SQL CONNECT TO sampleEXEC SQL SELECT FIRSTNME INTO :firstnameFROM employeeWHERE LASTNAME = 'JOHNSON'printf( "First name = %s\n", firstname )EXEC SQL CONNECT RESETreturn 0}上面是一个简单的静态嵌入SQL
语句的应用程序。它包括了嵌入SQL的主要部分:(1)中的include SQLCA语句定义并描述了SQLCA的结构。SQLCA用于应用程序和
数据库之间的通讯,其中的SQLCODE返回SQL语祥和掘句执行后的结果状态。(2)在BEGIN DECLARE SECTION和END DECLARE SECTION之间定义了宿主变量。宿主变量可被SQL语句引用,也可以被C语言语句引用。它用于将程序中的数据通过SQL语句传给数据库管理器,或从数据库管理器接收查询的结果棚梁。在SQL语句中,主变量前均有“:”标志以示区别。(3)在每次访问数据库之前必须做CONNECT *** 作,以连接到某一个数据库上。这时,应该保证数据库实例已经启动。(4)是一条选择语句。它将表employee中的LASTNAME为“JOHNSON”的行数据的FIRSTNAME查出,谨核并将它放在firstname变量中。该语句返回一个结果。可以通过游标返回多个结果。当然,也可以包含update、insert和delete语句。(5)最后断开数据库的连接。从上例看出,每条嵌入式SQL语句都用EXEC SQL开始,表明它是一条SQL语句。这也是告诉预编译器在EXEC SQL和“;”之间是嵌入SQL语句。你陵枣那个update语句是有where条件的,也可能根本就没有符合where条件的记录存在,所以也就不会尺亏拆有被更新的情况。但这个语句是被成功执行了的。所以返空此回值是成功的。
大概是这么回事。
处理SQL读入流的步骤如下:
1.定义读入流:首先需要定义一个输入流,用于接收SQL查询的输入,可以是文件输入流、网络输入流或者字符串输入流等。
2.解析SQL语句:然后使用SQL解析器来解析SQL语句,以确定SQL的纤让各种组成部或闷分,包括表名,字段名,过滤条件等。
3.执行SQL查询:接下来执行SQL查询,从数据库中检索数据,并将查询结果放入缓冲区中。
4.缓冲处理:如果查询结果较多,比如超过1万条记录,则可以采用缓冲处理,将查询结果分成几块,分别处理,以衫竖弯减少内存的使用。
5.输出处理:最后将查询结果输出,可以在网页上显示,也可以保存到文件中,或者将查询结果作为参数传递给其他程序。
评论列表(0条)