当前位置 : 主页 > 编程语言 > delphi >

如何在Delphi中引用FireDAC中的字段名称

来源:互联网 收集:自由互联 发布时间:2021-06-23
我正在开发一个在多个数据库上运行的应用程序,其中许多数据库都有自己的方式来引用保留字作为字段名称,例如 例如 select `key` from mytable 要么 select "key" from mytable 要么 select [key] from
我正在开发一个在多个数据库上运行的应用程序,其中许多数据库都有自己的方式来引用保留字作为字段名称,例如
例如

select `key` from mytable

要么

select "key" from mytable

要么

select [key] from mytable

我想知道是否有一个预处理器命令(或其他一些机制)可以自动确定用于给定数据库的正确引号字符.是的(在有人评论之前)我不应该使用保留字来表示字段名称,但是模式已经预定义了(几十年前).

对于常量SQL命令字符串,您可以使用{id}标识符替换 escape sequence.示例用法:

FDQuery1.SQL.Text := 'SELECT {id Key} FROM {id MyTable}';
FDQuery1.Open;

对于代码中的分配,您可以将substitution variable宏与AsIdentifier访问器一起使用.示例用法:

FDQuery1.SQL.Text := 'SELECT &KeyCol FROM &TheTable';
FDQuery1.MacroByName('KeyCol').AsIdentifier := 'Key';
FDQuery1.MacroByName('TheTable').AsIdentifier := 'MyTable';
FDQuery1.Open;
网友评论