嵌入SQL

 嵌入SQL

连接到SAMPLE数据库,查询LASTNAME为JOHNSON的FIRSTNAME信息。
#include   <stdio.h>
#include   <stdlib.h>
#include   <string.h>
#include   "util.h "
#include   <sqlca.h>
EXEC   SQL   INCLUDE   SQLCA;   (1)
main()
{
EXEC   SQL   BEGIN   DECLARE   SECTION;   (2)
char   firstname[13];
char   userid[9];
char   passwd[19];
EXEC   SQL   END   DECLARE   SECTION;
EXEC   SQL   CONNECT   TO   sample;   (3)
EXEC   SQL   SELECT   FIRSTNME   INTO   :firstname   (4)  
FROM   employee
WHERE   LASTNAME   =   'JOHNSON ';(4)
printf(   "First   name   =   %s\n ",   firstname   );
EXEC   SQL   CONNECT   RESET;   (5)
return   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语句。如果一条嵌入式SQL语句占用多行,在C程序中可以用续行符“\”。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值