我试图在事务范围内获取插入行的主键,因为我不想让数据库处于逻辑上不一致的状态。
我的问题是我找不到一种方法来检索以前执行的查询的 ID 值,我想将其用于下一个插入查询。在事务生效时查询 PostgreSQL 数据库在非外键表中显示没有结果(该行尚未提交?)。我相信这是由于事务的隔离级别。
下面是我试图用生产代码做的事情,尽管为了清楚起见,稍微编辑并缩小到一个功能。const int lastInsertId
始终为 0,在这种情况下应该意味着没有找到任何值(从技术上讲,该toInt()
函数失败了)。我尝试手动插入一个有效的非外键行,然后调用LASTVAL()
它产生了预期的结果——插入行的 ID。
那么,我做错了什么?我在这里遗漏或误解了什么?
void createEntityWithoutForiegnKeyConstraint(const QString &nameOfEntity)
{
db_.transaction();
QSqlQuery insertQuery(db_);
insertQuery.prepare("INSERT INTO \"EntityWithoutForeignKey\" (\"name\") VALUES (:name);");
insertQuery.bindValue(":name", nameOfEntity);
execQuery(__LINE__, insertQuery);
QSqlQuery lastIdQuery("SELECT LASTVAL();", db_); // auto executes
const int lastInsertId = lastIdQuery.value(0).toInt();
if (lastInsertId <= 0) // 0 is not a valid ID
throw exception("Oh noes.");
createEntityWithForeignKeyConstraint(lastInsertId, someData);
if (!db_.commit())
db_.rollback();
}