在 jooq 中使用 postgres currval()
Using postgres currval() in jooq
我正在使用 postgres 数据库和 Java。我正在使用 Jooq 查询我的数据库。
我需要在我的 table 中进行插入,并获取由该插入生成的 primary_key/sequence。我知道在简单的 postgres 中我可以这样做:
这是我的 table 的样子:
CREATE TABLE "myTable" (
"id" SERIAL NOT NULL,
"some_text" TEXT NOT NULL,
PRIMARY KEY ("id")
);
这是插入查询:
INSERT INTO public.myTable(some_text)
VALUES ('myValue');
然后获取最新的序列,
SELECT currval('myTableName_myColumnName_seq')
FROM myTable;
1) 如何在 JOOQ 中使用 currval?
现在我正在尝试这样的事情:
config.dsl().insertInto(Tables.myTable)
.set(Tables.myTable.myText, inputText)
.execute();
config.dsl().select.currval('myTableName_myColumnName_seq')
.from myTable;
但是最后一条语句出错了。
您的解决方案的问题是,当您向 table 中插入记录时,可能有另一个进程从序列中获取值,您将在第二个查询中得到错误的值 (SELECT currval
).
PostgreSQL 允许您在带有 RETURNING
子句的 INSERT
语句中取回一些数据:
INSERT INTO public.myTable(some_text)
VALUES ('myValue')
RETURNING id;
正如 jOOQ 手册所述,在这种情况下你应该使用 returning
和 fetch
。我不确定是否正确使用(我不熟悉 jOOQ),如下所示:
config.dsl().insertInto(Tables.myTable)
.set(Tables.myTable.myText, inputText)
.returning(Tables.myTable.id)
.fetch();
您可以通过 Sequence.currval()
获取序列的当前值,其中 returns 是用于该目的的表达式。例如
dsl().select(MYTABLENAME_MYCOLUMNNAME_SEQ.currval()).from(...)
但由于此序列是从 SERIAL
自动生成的,它会在您插入时自动生成序列值,我完全同意 ,您应该改用 INSERT .. RETURNING
。
我正在使用 postgres 数据库和 Java。我正在使用 Jooq 查询我的数据库。 我需要在我的 table 中进行插入,并获取由该插入生成的 primary_key/sequence。我知道在简单的 postgres 中我可以这样做:
这是我的 table 的样子:
CREATE TABLE "myTable" (
"id" SERIAL NOT NULL,
"some_text" TEXT NOT NULL,
PRIMARY KEY ("id")
);
这是插入查询:
INSERT INTO public.myTable(some_text)
VALUES ('myValue');
然后获取最新的序列,
SELECT currval('myTableName_myColumnName_seq')
FROM myTable;
1) 如何在 JOOQ 中使用 currval? 现在我正在尝试这样的事情:
config.dsl().insertInto(Tables.myTable)
.set(Tables.myTable.myText, inputText)
.execute();
config.dsl().select.currval('myTableName_myColumnName_seq')
.from myTable;
但是最后一条语句出错了。
您的解决方案的问题是,当您向 table 中插入记录时,可能有另一个进程从序列中获取值,您将在第二个查询中得到错误的值 (SELECT currval
).
PostgreSQL 允许您在带有 RETURNING
子句的 INSERT
语句中取回一些数据:
INSERT INTO public.myTable(some_text)
VALUES ('myValue')
RETURNING id;
正如 jOOQ 手册所述,在这种情况下你应该使用 returning
和 fetch
。我不确定是否正确使用(我不熟悉 jOOQ),如下所示:
config.dsl().insertInto(Tables.myTable)
.set(Tables.myTable.myText, inputText)
.returning(Tables.myTable.id)
.fetch();
您可以通过 Sequence.currval()
获取序列的当前值,其中 returns 是用于该目的的表达式。例如
dsl().select(MYTABLENAME_MYCOLUMNNAME_SEQ.currval()).from(...)
但由于此序列是从 SERIAL
自动生成的,它会在您插入时自动生成序列值,我完全同意 INSERT .. RETURNING
。