EVariantInvalidArgError Invalid argument
我在做一个三层时(使用TSocketConnection),正常查询没有问题。
但我在TCPSERVER.execute中查询时,则提示如标题的错误。怎么解决?
如果查询本地数据库,也没有问题
简单测试代码如下:
//以下如果直接调用,没有问题。procedure TForm1.GetIDFromMAC(Mac: string);begin try//如果将下面的查询,改成本地数据,没有问题 CDSSearch是连接远程数据库。 CDSSearch.Close; CDSSearch.CommandText:='Select * from HostList Where Trim(MAC) = "'+MAC+'"'; CDSSearch.Open; if CDSSearch.IsEmpty then ShowMessage('can''t find') else ShowMessage('find it'); except on E:Exception do ShowMessage(e.Message); end;end;procedure TForm1.TcpServerExecute(AContext: TIdContext);begin GetIDFromMAC('00:10:23:14');end;procedure TForm1.GetIDFromMAC(Mac: string);begin try//如果将下面的查询,改成本地数据,没有问题 CDSSearch是连接远程数据库。 CDSSearch.Close; CDSSearch.CommandText:='Select * from HostList Where Trim(MAC) = "'+MAC+'"'; CDSSearch.Open; if CDSSearch.IsEmpty then ShowMessage('can''t find') else ShowMessage('find it'); except on E:Exception do ShowMessage(e.Message); end;
[解决办法]
帮顶
[解决办法]
你在edit後,show一下FieldByName('Mac').AsString,確認是否為要編輯的記錄
[解决办法]
ApplyUpdates(-1);
要对应一个没有其它对象引用的socketconneting连接!
所以我认为不怎么好用
你可以在cds的对应的字段的onchange事件中写update语句,更好!