4

我想使用 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

4

1 回答 1

9

要设置参数的属性,您必须使用该Params属性。从这里您可以使用索引或名称访问每个参数,设置参数的值使用属性 AsStringAsInteger等之一,取决于字段的类型。

检查这个样本

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;
于 2012-06-20T20:32:27.353 回答