在PostgreSQL中,如何将最后一个id插入到表中?
在MS SQL中有SCOPE_IDENTITY()。
请不要建议我使用这样的东西:
select max(id) from table
在PostgreSQL中,如何将最后一个id插入到表中?
在MS SQL中有SCOPE_IDENTITY()。
请不要建议我使用这样的东西:
select max(id) from table
当前回答
试试这个:
select nextval('my_seq_name'); // Returns next value
如果这个返回1(或者你的序列的start_value),那么将序列重置回原始值,传递false标志:
select setval('my_seq_name', 1, false);
否则,
select setval('my_seq_name', nextValue - 1, true);
这将把序列值恢复到原始状态,“setval”将返回您正在寻找的序列值。
其他回答
参见INSERT语句的RETURNING子句。基本上,INSERT可兼做查询,并返回插入的值。
请参阅下面的示例
CREATE TABLE users (
-- make the "id" column a primary key; this also creates
-- a UNIQUE constraint and a b+-tree index on the column
id SERIAL PRIMARY KEY,
name TEXT,
age INT4
);
INSERT INTO users (name, age) VALUES ('Mozart', 20);
然后,要获取最后插入的id,请使用下面的语句对user表执行seq列名为id
SELECT currval(pg_get_serial_sequence('users', 'id'));
我在使用Java和Postgres时遇到了这个问题。 我通过更新一个新的Connector-J版本来解决这个问题。
postgresql - 9.2 - 1002. - jdbc4.jar
https://jdbc.postgresql.org/download.html: 版本42.2.12
https://jdbc.postgresql.org/download/postgresql-42.2.12.jar
Postgres有一个内置的机制,可以在同一个查询中返回id或任何您希望查询返回的内容。 这里有一个例子。假设您创建了一个有两列columnn1和column2的表,并且希望在每次插入后返回columnn1。
# create table users_table(id serial not null primary key, name character varying);
CREATE TABLE
#insert into users_table(name) VALUES ('Jon Snow') RETURNING id;
id
----
1
(1 row)
# insert into users_table(name) VALUES ('Arya Stark') RETURNING id;
id
----
2
(1 row)
试试这个:
select nextval('my_seq_name'); // Returns next value
如果这个返回1(或者你的序列的start_value),那么将序列重置回原始值,传递false标志:
select setval('my_seq_name', 1, false);
否则,
select setval('my_seq_name', nextValue - 1, true);
这将把序列值恢复到原始状态,“setval”将返回您正在寻找的序列值。