将SQL嵌入到高级语言中混合编程,程序中会含有两种不同计算模型的语句:
(1)SQL语句:描述性的面向集合的语句;负责操纵数据库
(2)高级语言语句:过程性的面向记录的语句;负责控制程序流程。
工作单元之间的通信方式:
1. SQL通信区:向主语言传递SQL语句的执行状态信息;主语言能够据此控制程序流程
2. 主变量:
(1)主语言向SQL语句提供参数。
(2)将SQL语句查询数据库的结果交主语言进一步处理。
3. 游标:解决集合性操作语言与过程性操作语言的不匹配。
一、SQL通信区
SQLCA: SQL Communication Area。SQLCA是一个数据结构
SQLCA的用途:
SQL语句执行后,DBMS反馈给应用程序信息
(1)描述系统当前工作状态
(2)描述运行环境
这些信息将送到SQL通信区SQLCA中,应用程序从SQLCA中取出这些状态信息,据此
决定接下来执行的语句。
SQLCA的使用方法:
用EXEC SQL INCLUDE SQLCA加以定义。SQLCA中有一个存放每次执行SQL语句后返回
代码的变量SQLCODE。如果SQLCODE等于预定义的量SUCCESS,则表示SQL语句成功,
否则表示出错;应用程序每执行完一条SQL 语句之后都应该测试一下SQLCODE的值,
以了解该SQL语句执行情况并做相应处理。
例:在执行删除语句DELETE后,不同的执行情况ÿ