我想使用dbExpress TSQLQuery组件。但我不知道如何编写SQL来添加参数。我会举一个例子,也许会更清楚我的问题是什么。
在TADOQuery中,以下工作:
SELECT*
FROM sometable
WHERE sometable.id = :value;
现在在上面的示例中,您使用参数名称前面的冒号(:)将参数传递给查询。但是当我尝试使用TSQLQuery执行此操作时,我收到以下错误:
dbExpress driver does not support the TDBXTypes.UNKNOWN data type. Vendor Error Message.
现在,如果这不是您在TSQLQuery组件中传递参数的方式,那么有人可以帮助我。这对我来说是个新领域。
我正在使用Firebird数据库,我正在使用Delphi XE2
答案 0 :(得分:8)
要设置参数的属性,必须使用Params
属性。从这里你可以使用索引或名称访问每个参数,设置参数的值使用properties AsString之一,AsInteger等等,取决于类型场。
检查此样本
var
LSQLQuery : TSQLQuery;
begin
LSQLQuery:=TSQLQuery.Create(nil);
try
LSQLQuery.SQLConnection:=SQLConnection1;
LSQLQuery.CommandText:='Select FIRST_NAME from EMPLOYEE Where EMP_NO=:Param1';
LSQLQuery.Params.ParamByName('Param1').AsInteger:=2;//or using the index of the parameter LSQLQuery.Params[0].AsInteger:=2;
LSQLQuery.Open;//Execute the query
ShowMessage(LSQLQuery.FieldByName('FIRST_NAME').AsString); //get the data
LSQLQuery.Close;
finally
LSQLQuery.Free;
end;
end;