SQL - 插入一行并返回主键

新手上路,请多包涵

我在存在主键的表中插入了一行包含一些数据的行。如何“选择”刚刚插入的第一行的主键?

我应该更具体一些,并提到我目前正在使用 SQLite。

原文由 Samuel Moriarty 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 902
2 个回答

对于 MS SQL 服务器:

SCOPE_IDENTITY() 将返回您当前范围内最后生成的标识值:

 SELECT SCOPE_IDENTITY() AS NewID

原文由 Michael Fredrickson 发布,翻译遵循 CC BY-SA 3.0 许可协议

对于 PostgreSQL,

 INSERT INTO tablename (col1, col2, ...)
VALUES (val1, val2, ...)
RETURNING idcol;

可选的 RETURNING 子句使 INSERT 根据实际插入的每一行(或更新的,如果使用了 ON CONFLICT DO UPDATE 子句)计算并返回值。这主要用于获取默认提供的值,例如序列号。但是,任何使用表列的表达式都是允许的。

https://www.postgresql.org/docs/current/sql-insert.html

原文由 Brian Burns 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
logo
Stack Overflow 翻译
子站问答
访问
宣传栏