初涉嵌入式SQL(ESQL)

      嵌入式 SQL (ESQL) 是用于 SQL 数据库访问的 SQL-92 标准应用程序接口 (API)。ESQL 的编译需要分两步进行:
      1.预编译器将嵌入式 SQL 语句翻译成编写该应用程序所使用的编程语言中的命令。生成的语句专供提供预编译器的数据库使用,因此,虽然原始源程序与 ESQL 同类,但生成的语句和最后的可执行文件专门用于某个数据库供应商。
      2.然后,用应用程序编程语言的编译器编译由预编译器生成的源程序。

      与 OLE DB 这类 COM API 或 ODBC 这类调用级接口相比,嵌入式 SQL 的语法更简单,因此更易于学习和编程。但嵌入式 SQL 不如 OLE DB 或 ODBC 灵活,在用 OLE DB 或 ODBC 精心编写的应用程序中,只需切换驱动程序或提供程序,即可从一个 DBMS 切换到另一个。在编译应用程序(例如开发按需查询工具时)时不识别 SQL 语句的环境中,更适合使用 OLE DB 和 ODBC,另外还有一个国家"八五"科技攻关课题"国产系统软件开发"研制开发的关系数据库管理系统,COBASE系统,也提供了对ESQL的支持。对于其它数据库的支持,大家可自已去查阅相关资料。

      许多数据库都提供了ESQL 的库,如ORACLE的PRO*C,一般放在precomp目录下;PostgreSQL的ecpg,可在http://www.pgsqldb.org /pgsqldoc-8.1c/ecpg.html查到相关的中文文档;Informix 数据库系统的INFORMIX-ESQL/C。

      另外,Microsoft? SQL Server? 2000 也提供了用于 C 应用程序的嵌入式 SQL 预编译器。这个 SQL Server 预编译器将嵌入式 SQL语句翻译成对适当 DB-Library API 函数的调用。Microsoft 实现的 ESQL 与 DB-Library 应用程序有相同的限制。

      SQL Server 旨在支持用与 Microsoft SQL Server 兼容的第三方嵌入式 SQL 预编译器编译的 COBOL 嵌入式 SQL 应用程序。

一、PRO*C简介
      ORACLE除了提供SQL * PLUS,SQL * FORMS等数据库访问工具进行数据库访问外还可以在第三代高级语言中内嵌SQL语句或ORACLE函数的方式来访问ORACLE数据库。目前 ORACLE支持的语言有C,FORTRAN,PASCAL等,采用C的部分就叫做PRO*C。其中内嵌的SQL语句包括了DML,DDL语句,可以实现动态的建立,修改,删除数据库中的表,也可以查询,插入,删除表中的表中的行,实现数据库操作的提交和回滚。使用第三代高级语言内嵌SQL语句的好处有如下三点:

1、过程化语言与非过程化语言相结合可以满足各种复杂要求的应用,还可以引用窗口和鼠标技术。
2、可以使开发的应用程序具有管理资源,SQL语句执行和指示器等能力
3、提高应用程序的执行速度。

      所有PRO*C的程序在编译前都要经过ORACLE的预编译系统进行预编译,预编译系统允许采用动态SQL技术,能实现内部和外部数据类型的转换,可以嵌入 PL/SQL块,能用数据类型等价来控制ORACLE解释输入数据和格式化输出数据,可以检查嵌入的SQL语句的语法和语义,可以使用数组SQL变量能利用SQLCA和ORACA进行错误诊断。

二、PRO*C程序结构

      一般PRO*C主要有外部说明段与程序主体两部分组成。

外部说明段:主要说明了程序中要引用到的外部变量和函数,包括了说明段,通讯区说明和C语言的相关声明。

程序主体:同一般C程序的主体部分,可以用多个函数或仅有MAIN函数。函数中又可以包含局部说明段,局部通讯区声明和C局部变量声明。

说明段语法如下:

EXEC SQL BEGIN DECLARE SECTION;

(SQL变量声明)

EXEC SQL END DECLARE SECTION;

通讯区说明语句为:EXEC SQL INCLUDE SQLCA;

其中SQLCA为结构体,具体内容可以查看ORACLE预编译系统的头文件sqlca.h(windows 下的路径为:$orahome/precomp/public/)

struct   sqlca
{
    char    sqlcaid[8];
    int     sqlabc;
    int     sqlcode;    /*等同与SQLCODE指示SQL错误代码
    struct
     {                        /*结构体等同于SQLERRM用户贮存SQL错误信息。
         unsigned short sqlerrml;
         char           sqlerrmc[70];
     } sqlerrm;
    char    sqlerrp[8];
    int     sqlerrd[6];
    char    sqlwarn[8];
    char    sqlext[8];
};

      以上是对ESQL的一些介绍,网上资料比较散乱,稍微整理一下,欢迎大家批评指正。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值