【发布时间】:2018-06-01 12:29:30
【问题描述】:
我正在学习如何使用 insert into 语句,并使用我的 access 数据库尝试插入一条记录。我要插入新记录的表有三个字段:StockID (AutoN)、Description (Text)、Cost (Number)。我看过以前的帖子,但发布的解决方案似乎超出了我的基本插入水平...这是我感兴趣的。无论如何,这是我的代码...
adoQuery1.Active := true;
adoQuery1.SQL.Clear;
adoQuery1.SQL.Add('INSERT INTO Stock (StockID,Description,Cost) VALUES (4,Cheese,5)');
adoQuery1.open;
adoQuery1.Close;
它编译得很好,但是当按下命令按钮来调用上述内容时,我收到以下消息:
'ADOQuery1:“缺少 SQL 属性”。'
我做错了什么?
谢谢,Abelisto。您的上一篇文章确实看起来很复杂……但是自从您的上一个解决方案让我启动并运行以来,我做了自己的小版本。它有效,所以我很高兴。我现在将专注于使用组合框(用于字段选择)和用户值删除。这是我开始工作的解决方案... ;)
x:=strtoint(txtStockID.Text);
y:=txtDescription.Text;
z:=strtoCurr(txtCost.Text);
adoQuery1.SQL.Clear;
adoQuery1.SQL.Add('INSERT INTO tblStock (StockID,Description,Cost)');
adoQuery1.SQL.Add('VALUES (:StockID,:Description,:Cost)'); // ':StockID' denotes a parameter
adoQuery1.Parameters.ParamByName('StockID').Value:= x;
adoQuery1.Parameters.ParamByName('Description').Value:= y;
adoQuery1.Parameters.ParamByName('Cost').Value:= z;
adoQuery1.ExecSQL;
adoQuery1.Close;
【问题讨论】:
-
请致电 ExecSQL 而不是
Open。也不要设置Active属性 - 它与select类似的语句相关,而不是 DML。 -
感谢 Abelisto,删除了 ExecSQL 和 Active 属性...但我在进行更改后收到错误消息“参数太少。预期为 1”。我的价值观好吗? IE。我应该在某处使用撇号吗?
-
VALUES (4,Cheese,5)->VALUES (4,''Cheese'',5)(不是双引号,而是两个撇号)或VALUES (4,' + QuotedStr('Cheese') + ',5),别忘了删除adoQuery1.Active := true; -
已经排序了。非常感谢 Abelisto。对于像我这样的新手来说,您的指示清晰易懂。 ; )
-
PS:
adoQuery1.Close;在这种情况下是不必要的。祝你好运。