技术开发 频道

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

  【IT168 技术】将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后,不同的执行情况,SQLCA中有不同的信息:

  · 违反数据保护规则,操作拒绝。

  · 没有满足条件的行,一行也没有删除。

  · 成功删除,并有删除的行数。

  · 无条件删除警告信息。

  · 由于各种原因,执行出错。

  二、主变量

  嵌入式SQL语句中可以使用主语言的程序变量来输入或输出数据。在SQL语句中使用的主语言程序变量简称为主变量(Host Variable)。

  主变量的类型:

  1、 输入主变量:由应用程序对其赋值,SQL语句引用。

  2、 输出主变量:由SQL语句赋值或设置状态信息,返回给应用程序。

  3、 一个主变量有可能既是输入主变量又是输出主变量。

  4、 一个主变量可以附带一个指示变量(Indicator Variable)。

  5、 指示变量一个整型变量,用来“指示”所指主变量的值或条件。

  指示变量的用途:输入主变量可以利用指示变量赋空值;输出主变量可以利用指示变量检测出是否空值,值是否被截断。

  在SQL语句中使用主变量和指示变量的方法:

  1、 说明主变量和指示变量

  BEGIN DECLARE SECTION
  .........
  ......... (说明主变量和指示变量)
  .........
  
END DECLARE SECTION

  2、 使用主变量

  说明之后的主变量可以在SQL语句中任何一个能够使用表达式的地方出现,为了与数据库对象名(表名、视图名、列名等)区别,SQL语句中的主变量名前要加冒号(:)作为标志。

  3、 使用指示变量

  · 指示变量前也必须加冒号标志。

  · 必须紧跟在所指主变量之后。

  · 在SQL语句之外(主语言语句中)使用主变量和指示变量的方法。

  · 可以直接引用,不必加冒号。

0
相关文章