一个嵌入式 SQL 程序由用普通编程语言(此处为 C 语言)编写的代码和用特殊标记的部分混合的 SQL 命令组成。要构建该程序,源代码(*.pgc
)首先会通过嵌入式 SQL 预处理器,该预处理器将其转换为普通的 C 程序(*.c
),然后可以通过 C 编译器进行处理。(有关编译和链接的详细信息,请参阅第 34.10 节。)转换后的 ECPG 应用程序通过嵌入式 SQL 库(ecpglib)调用 libpq 库中的函数,并使用普通的前端-后端协议与 PostgreSQL 服务器通信。
嵌入式SQL与从 C 代码处理SQL命令的其他方法相比,具有优势。首先,它处理从C程序中变量的来回传递信息的繁琐工作。其次,程序中的 SQL 代码在构建时会检查语法正确性。第三,嵌入式SQL在 C 中是在SQL标准中指定的,并受到许多其他SQL数据库系统的支持。PostgreSQL 实现旨在尽可能地符合此标准,通常可以相对轻松地将为其他 SQL 数据库编写的嵌入式SQL程序移植到 PostgreSQL。
如前所述,为嵌入式SQL接口编写的程序是正常的 C 程序,其中插入了特殊的代码来执行与数据库相关的操作。此特殊代码始终具有以下形式
EXEC SQL ...;
这些语句在语法上代替了 C 语句。根据特定的语句,它们可以出现在全局级别或函数内部。
嵌入式SQLEXEC SQL
语句遵循普通SQL代码的大小写敏感规则,而不是 C 的规则。它们还允许根据 SQL 标准使用嵌套的 C 风格注释。但是,程序的 C 部分遵循 C 标准,不接受嵌套注释。嵌入式SQL语句同样使用 SQL 规则,而不是 C 规则,来解析带引号的字符串和标识符。(请参阅第 4.1.2.1 节和第 4.1.1 节。)请注意,ECPG 假定 standard_conforming_strings
为 on
。)当然,程序的 C 部分遵循 C 引用规则。
以下各节解释了所有嵌入式 SQL 语句。
如果您在文档中发现任何不正确、与您对特定功能的体验不符或需要进一步澄清的内容,请使用此表格报告文档问题。