如何将 TParams (TQuery) 对象转换为 TParameters (ADO) 对象。?
How to Convert a TParams (TQuery) Object to TParameters (ADO) object.?
我正在处理包含一些 TQuery 组件的遗留代码。我试图创建一个将 TQuery 参数转换为 TParameters 的函数,以便我可以将它们分配给 ADO 组件(如 ADOQuery 或 ADODataSet)的参数 属性。
我尝试了以下从互联网上获得的方法。
function ConvertToADOParms(Owner: TADODataset; aParams: TParams): TParameters;
var i: integer;
begin
// Convert a standard TParams object to an ADO-specific TParameters object
Result :=nil;
try
if aParams = nil then exit;
Result :=TParameters.create( Owner, TParameter);
for i:=0 to aParams.count - 1 do
begin
if aParams[i] = nil then continue;
with Result.AddParameter do
begin
Name := aParams[i].Name;
Datatype :=aParams[i].DataType;
Direction :=TParameterDirection(aParams[i].ParamType);
Size :=aParams[i].size;
Value :=aParams[i].value;
end;
end;
except
on e:exception do
begin
Result :=nil;
showmessage('Could not convert standard parameter object to ADO parameter object: '+e.message);
end;
end;
end;
但我收到无效 Class 类型转换错误。当我调试代码时,我发现错误发生在 ADODB unit
中的这个函数
function TParameters.GetCommand: TADOCommand;
begin
Result := GetOwner as TADOCommand;
end;
请帮助。我正在使用 Delphi 5
我不太了解函数原型。它请求函数返回的集合的所有者,因此恕我直言应该是独立的。
我会简单地摆脱它并直接使用传递的 ADO 对象进行操作。例如:
procedure FillParamsADO(Params: TParams; Dataset: TADODataset);
var
i: Integer;
begin
Dataset.Parameters.Clear;
for i := 0 to Params.Count-1 do
begin
with Dataset.Parameters.AddParameter do
begin
Name := Params[i].Name;
DataType := Params[i].DataType;
Direction := TParameterDirection(Params[i].ParamType);
Size := Params[i].Size;
Value := Params[i].Value;
end;
end;
end;
我正在处理包含一些 TQuery 组件的遗留代码。我试图创建一个将 TQuery 参数转换为 TParameters 的函数,以便我可以将它们分配给 ADO 组件(如 ADOQuery 或 ADODataSet)的参数 属性。
我尝试了以下从互联网上获得的方法。
function ConvertToADOParms(Owner: TADODataset; aParams: TParams): TParameters;
var i: integer;
begin
// Convert a standard TParams object to an ADO-specific TParameters object
Result :=nil;
try
if aParams = nil then exit;
Result :=TParameters.create( Owner, TParameter);
for i:=0 to aParams.count - 1 do
begin
if aParams[i] = nil then continue;
with Result.AddParameter do
begin
Name := aParams[i].Name;
Datatype :=aParams[i].DataType;
Direction :=TParameterDirection(aParams[i].ParamType);
Size :=aParams[i].size;
Value :=aParams[i].value;
end;
end;
except
on e:exception do
begin
Result :=nil;
showmessage('Could not convert standard parameter object to ADO parameter object: '+e.message);
end;
end;
end;
但我收到无效 Class 类型转换错误。当我调试代码时,我发现错误发生在 ADODB unit
中的这个函数function TParameters.GetCommand: TADOCommand;
begin
Result := GetOwner as TADOCommand;
end;
请帮助。我正在使用 Delphi 5
我不太了解函数原型。它请求函数返回的集合的所有者,因此恕我直言应该是独立的。
我会简单地摆脱它并直接使用传递的 ADO 对象进行操作。例如:
procedure FillParamsADO(Params: TParams; Dataset: TADODataset);
var
i: Integer;
begin
Dataset.Parameters.Clear;
for i := 0 to Params.Count-1 do
begin
with Dataset.Parameters.AddParameter do
begin
Name := Params[i].Name;
DataType := Params[i].DataType;
Direction := TParameterDirection(Params[i].ParamType);
Size := Params[i].Size;
Value := Params[i].Value;
end;
end;
end;