Firedac 将列名作为参数传递

Firedac Passing Column name as Parameter

在 Delphi Firedac 中,我有一个很长的查询。我想重用它只是通过这样的参数更改列的名称

select f1, f2
from t1
where id = :par1
and :colimn_name = :value_name

传递 :column_name 参数,结果查询如下:

select f1, f2
from t1
where id = 123
and 'department_name' = 'production'

用 2 '' 包裹列名。

如何避免这种情况,FireDAC 中是否有特定的方法?

谢谢。

这就是 FireDAC 提供宏的目的:Substitution Variables

select f1, f2
from t1
where id = :par1
and &column_name = :value_name

设置实际的列是这样的:

myQuery.MacroByName('column_name').AsRaw := 'department_name';

编辑: 由于列名恰好是数据库 标识符,因此使用 AsIdentifier 而不是 AsRaw 也应该工作。当列名可以是数据库中的某个保留字并且必须以某种方式引用时,这甚至可能是必要的。