当前位置: 首页 > 面试题库 >

在SQLite上获取最后插入的行的ID的最佳方法

姬乐池
2023-03-14
问题内容

在iPhone上,使用FMDB获取SQLite数据库中最后插入的行的ID的最佳方法是什么?

有没有比做更好的方法:

SELECT MAX(ID)

问题答案:

如果可以保证您的ID列是自动递增的列,那MAX(ID)很好。

但不管怎样,有一个专门的SQLite函数称为LAST_INSERT_ROWID()

SELECT LAST_INSERT_ROWID();

在FMDB中,您使用-lastInsertRowId方法(在内部运行上述方法):

int lastId = [fmdb lastInsertRowId];


 类似资料:
  • 问题内容: 使用Java中的sqlite获取最后插入的ID的最佳方法是什么?Google给了我不同的答案-有人说选择last-insert- rowid;其他人说调用statement.getGeneratedKeys()。最好的路线是什么?(我只想返回id,而不将其用于其他插入或其他操作。) 问题答案: 如果您的JDBC驱动程序支持它,则使用它。您不想在插入后尝试自己获取密钥。如果您的驱动程序不

  • 问题内容: 我有一个查询,我想插入最后一个ID。字段ID是主键,并且是自动递增的。 我知道我必须使用以下语句: 该语句适用于如下查询: 但是,如果我想使用以下语句获取ID: 我收到此错误: 我究竟做错了什么? 问题答案: 那是因为那是SQL函数,而不是PHP。您可以使用。 喜欢: 如果要使用SQL而不是PDO API进行操作,则可以像普通的select查询一样进行操作:

  • 问题内容: …并且该手册似乎表明您可以随时拨打电话,并且可以正常使用。但是这个… …似乎说明它必须在事务内。所以我的问题是:我可以在查询之前(只要没有交易)就等我想要的时间吗?面对许多并发连接,这可靠吗? 问题答案: PostgreSQL中的INSERT,UPDATE和DELETE具有RETURNING子句,这意味着您可以执行以下操作: 然后查询将为插入的每一行返回它为id插入的值。将往返保存到服

  • 问题内容: 是否有任何选项可以获取CodeIgniter中新记录的最后插入ID? 考虑字段id(自动递增)firstcolumn和secondcolumn的表组成。 这样,您可以在以下代码中使用插入ID。 问题答案: 真可惜 我看了一下用户指南,第一个功能是 这也适用于activerecord插入… 编辑:我更新了链接

  • 问题内容: 我使用以下查询将多个记录插入到表中: 由于查询要插入多个记录,因此无法使用 SCOPE_IDENTITY 来检索PK。有什么方法可以获取最近插入记录的ID? 问题答案: SCOPE_IDENTITY()将正确为您提供LAST ID。您需要将其与@@ Rowcount结合使用,以提供ID范围。 正如其他Richard指出的那样 ,这仅在您将增量设置为1时有效 例如: 执行此操作的另一种方

  • 问题内容: 我正在使用PHP中的mvc结构,我想检索最后插入的行ID。 我创建了以下sql代码: 但不幸的是我遇到了这个错误: 我也尝试过此堆栈链接,但不适用于我,因此如果您能帮助我获取ID,我将非常高兴。 我也在这里共享我的controller.php文件。 问题答案: 你快到了。 如果您查看lastInsertId的手册页,则会在数据库句柄上调用它- 您当前正在语句中对其进行调用。 您只需要致