2

我需要帮助解决以下问题。我已经使用以下组件类型实现了一个可编辑的 DBGrid:TQuery、TDataSource、TUpdateSQL、TDBGrid。Query AfterPost 事件处理程序将更改应用于数据库。

procedure TCardForm.Query2AfterPost(DataSet: TDataSet);
begin
  Query2.ApplyUpdates;
end;

因此,如果我在 DBGrid 中编辑一行并移动到另一行或按下向下箭头键,我所做的更改将应用​​于数据库。一切正常,只有一个例外。当输入不正确的值时,会引发数据库异常并显示一条消息,例如“Column ... cannot be NULL”。在消息框中单击“确定”后,应用程序允许我浏览 DBGrid 并转到另一行,而无需尝试应用更改,也不会再次显示异常消息。仅当我编辑另一行或再次编辑同一行时,它才会显示异常消息。我不希望应用程序允许我这样做。在输入正确的值之前,我希望无法移动到 DBGrid 中的另一行。

提前感谢您的回答!

4

1 回答 1

0

Most probably you should handle the error in try except block. Or validate entries before posting to database.

于 2012-10-16T14:25:29.643 回答