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
也应该工作。当列名可以是数据库中的某个保留字并且必须以某种方式引用时,这甚至可能是必要的。
在 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
也应该工作。当列名可以是数据库中的某个保留字并且必须以某种方式引用时,这甚至可能是必要的。