1

当我开发一个 GUI 窗口应用程序时,我看到在 PostgreSQL 中插入一行的奇怪行为。

我的应用程序(由 Xojo 构建)构建了一个 JOB 元信息并将其插入 PostgreSQL,我尝试运行 5 个作业,每个作业插入一行。它冻结了 GUI 应用程序。当我运行 4 个作业时,我没有看到任何问题,但 5 个会导致此问题。

试图记录代码,我发现其中一项工作无法通过“BEGIN TRANSACTION”语句传递。数据库中没有锁定信息,这就是我卡住的原因。

可能在同一个表中同时插入行有一些限制?有时,由于 ini_trans(Oracle) 的数量很少,并发 DML 可能会卡住。我不确定 PostgreSQL 是否具有该功能。

每个作业都应通过以下步骤来提交一行。

  mPostgreSQLDB.SQLExecute("BEGIN TRANSACTION")
  mPostgreSQLDB.SQLExecute (insert_statement)

  If mPostgreSQLDB.Error then
    Logging("DML failed. Error: " + mPostgreSQLDB.ErrorMessage + " Rollbacked " )
    mPostgreSQLDB.Rollback
  Else
    mPostgreSQLDB.Commit
  End If

更正。

我注意到有另一个 UPDATE 语句来记录同一张表的日期。但是,INSERT 和 UPDATE 处理不同的行,但即使没有锁定信息,它们似乎也会相互阻塞。

4

1 回答 1

1

您应该在 BEGIN TRANSACTION 步骤之后检查任何错误。任何使用 SQLExecute 的东西都可能产生数据库错误。我打赌你会收到一条错误消息,它可能会告诉你到底发生了什么。

于 2016-08-06T16:31:23.317 回答