2

我有一个 TSqlDataSet 有一个 blob 字段,我需要在提供者的 BeforeUpdateRecord 事件中获取这个 blob 字段的数据并执行更新命令,我试过这个:

Cmd := TSQLQuery.Create(nil);
try
  Cmd.SQLConnection := SQLConnection;
  Cmd.CommandText := 'UPDATE MYTABLE SET IMAGE = :PIMAGE WHERE ID = :PID';
  Cmd.Params.CreateParam(ftBlob, 'PIMAGE ', ptInput).Value := DeltaDS.FieldByName('IMAGE').NewValue; //blob field
  Cmd.Params.CreateParam(ftString, 'PID', ptInput).Value := DeltaDS.FieldByName('ID').NewValue;
  Cmd.ExecSQL;
finally
  Cmd.Free;
end;

当我执行时,我得到一个带有消息的 EDatabaseError:'参数 PIMAGE 没有值。

我错过了什么?

4

2 回答 2

2

回答我自己的问题,正确的方法如下:

const
  SQL = 'UPDATE MYTABLE SET IMAGE = :PIMAGE WHERE ID = :PID;';
var
  Params: TParams;
begin
  Params := TParams.Create(nil);
  try
    Params.CreateParam(ftBlob, 'PIMAGE', ptInput).AsBlob := DeltaDS.FieldByName('IMAGE').NewValue;
    Params.CreateParam(ftString, 'PID', ptInput).Value := DeltaDS.FieldByName('ID').NewValue;
    SQLConnection.Execute(SQL, Params);
  finally
    Params.Free;
  end;
end;
于 2008-12-01T12:16:33.857 回答
0

您是否尝试过使用其他驱动程序(例如 ODBC)进行测试?错误可能不在您的代码中。这种方法(更改数据提供者/驱动程序)帮助我解决了一些令人困惑的问题,这些问题最终证明不是我的问题。

于 2008-11-29T02:56:54.270 回答