Table of Contents
这一章描述了用于PostgreSQL的嵌入式SQL包。它由 Linus Tolke(<linus@epact.se>)和 Michael Meskes(<meskes@postgresql.org>)编写。最初它是为了与C一起工作而编写的。它也能与C++配合,但是它还不识别所有的C++结构。
这份文档还很不完整。不过,由于这一接口是标准化的,因此可以在许多关于 SQL 的资料中找到补充信息。
嵌入式 SQL 程序由普通编程语言编写的代码(这里是 C)与位于特殊标记区段中的 SQL 命令混合组成。 要构建该程序,首先要将源代码(*.pgc)交给嵌入式 SQL 预处理器,它会把源代码转换成普通 C 程序(*.c),之后就可以由 C 编译器处理。(关于编译和链接的细节见Section 34.10。) 转换后的 ECPG 应用会通过嵌入式 SQL 库(ecpglib)调用 libpq 库中的函数,并使用普通的前端/后端协议与 PostgreSQL 服务器通信。
与其他在 C 代码中处理SQL命令的方法相比,嵌入式SQL有其优势。首先,它能处理与你的C程序变量之间来回传递信息的繁琐工作。其次,程序中的 SQL 代码会在构建时接受语法正确性检查。第三,C 中的嵌入式SQL由SQL标准规定,并且得到许多其他SQL数据库系统的支持。PostgreSQL 的实现被设计为尽可能贴合该标准,因此通常可以比较容易地把为其他 SQL 数据库编写的嵌入式SQL程序移植到PostgreSQL。
如前所述,为嵌入式SQL接口编写的程序,本质上就是插入了用于执行数据库相关操作的特殊代码的普通 C 程序。这种特殊代码总是采用如下形式:
EXEC SQL ...;
这些语句在语法上取代了一个 C 语句。根据具体语句的不同,它们可以出现在全局层面,也可以出现在函数内部。
嵌入式SQL语句遵循普通SQL代码的大小写规则,而不是 C 的大小写规则。 它们也允许使用符合 SQL 标准的可嵌套 C 风格注释。 不过,程序的 C 部分遵循 C 标准,不接受嵌套注释。 对带引号的字符串和标识符进行语法解析时,嵌入式SQL语句同样采用 SQL 规则,而不是 C 规则。 (分别参见Section 4.1.2.1和Section 4.1.1。注意 ECPG 假定standard_conforming_strings为on。) 当然,程序的 C 部分仍遵循 C 的引号规则。
下列小节解释了所有嵌入式 SQL 语句。
如果您发现文档中有不正确的内容、与您使用特定功能的经验不符或需要进一步说明,请使用此表单来报告文档问题。