无法将Delphi ADOQuery更新或插入Excel工作表

时间:2018-05-16 08:21:38

标签: excel delphi ado tadoquery data-controls

我目前正在开发一个程序,其功能是从Excel电子表格中读取数据,用户应该可以编辑库存量并生成单独的库存报告,这是我已经完成的。尝试更新原始电子表格时出现问题,显示当用户在程序上添加/删除时,股票变得越来越少。

我已经能够显示DBGrid中的库存变化,但是没有对实际的电子表格进行任何更改,因此每当程序重新启动时,它将显示未更改的数字。(这是通过DBEdits完成的)

**我已经创建了一个较小版本的代码,以使我的问题更清晰,更容易阅读。使用查询来尝试更新Excel电子表格,电子表格中的第一行的值为17程序试图更改为5.每当我运行此代码时,我得到“更新语句中的语法错误”,我相当确定不是这种情况。我已经玩过添加诸如

之类的代码
  

ADOQuery.open   ADOQuery.Enabled:= false   ADOQuery.Enabled:= true

等。每个人都给我不同的错误。**

代码如下:

procedure TForm1.FormCreate(Sender: TObject);
begin

  //Building Connection string as well as recieving filename of excel document
  OpenDialog1.Execute;
  ADOQuery1.ConnectionString := 'Provider=Microsoft.Jet.OLEDB.4.0;' + 'Data Source=' + OpenDialog1.FileName + ';' + 'Extended Properties="Excel 8.0;IMEX=2"';

  //Working SQL statement to display records in DBGrid
  ADOQuery1.SQL.Clear;
  ADOQuery1.SQL.Add('SELECT * FROM [Sheet1$];');
  ADOQuery1.Active := true;

end;

procedure TForm1.Button1Click(Sender: TObject);
begin
   //Broken code, purpose is to replace the first row value with a new value
   ADOQuery1.SQL.Clear;

   ADOQuery1.SQL.Add('UPDATE [Sheet1$]');
   ADOQuery1.SQL.Add('SET Value = 5');
   ADOQuery1.SQL.Add('WHERE Value = 17;');

   ADOQuery1.ExecSQL;


end;

end.

示例电子表格: Sample Spreadsheet used in code above

我在过去的两天里对这个问题进行了研究,但不知何故,答案似乎总是让我不知所措,总是要求最后的努力。如果你不知道解决方案,任何指导都会受到赞赏,甚至对其他编程语言/ IDE的建议也会给我带来更丰富的成果。如果你能够将一个链接到我,这可能与我当前的程序相关,我甚至会选择一个Excel脚本教程

P.S很抱歉这么长的帖子,对这个网站来说相当新。非常感谢所有帮助。

1 个答案:

答案 0 :(得分:2)

我可以重现你的问题并获得

  

UPDATE语句中的语法错误。

更新后的答案我还没有对此进行全面调查,但我认为您的问题是由于您选择Value作为列名而引起的。我认为这个名称可能与ADO层解释UPDATE语句的方式有冲突。我认为,因为如果我使用这个Sql语句

  

'更新[Sheet1 $]设置[值] = 88,其中[值] = 5'

,查询正确执行并正确更新包含5的单元格的值。

我将在下面留下原来的答案,以防其他人帮忙。

原始回答:

要检查Value列的FieldName是否存在问题,我将其添加到TForm1.Create

  Caption := AdoQuery1.Fields[0].FieldName;

并确认FieldName确实是Value

然后我在表单中添加了TDBNavigator和TDBEdit,发现我可以毫无问题地编辑TDBEdit中的Value值。

这给了我一个想法:

procedure TForm1.Button2Click(Sender: TObject);
begin
  if AdoQuery1.Locate('Value', '5', []) then begin
    AdoQuery1.Edit;
    AdoQuery1.FieldByName('Value').AsString := '99';
    AdoQuery1.Post;
  end;
end;

并且工作正常。显然,这并不完全是你想要的,因为如果有多行与WHERE子句匹配,它并不能完全复制UPDATE语句会做什么,但有多种方法可以实现这一点,例如:使用AdoQuery的Seek方法。

如果我在UPDATE工作方面取得任何进展,我会发布此答案的更新。