gpt4 book ai didi

postgresql - 在 jooq 中使用 postgres currval()

转载 作者:行者123 更新时间:2023-11-29 12:36:19 24 4
gpt4 key购买 nike

我正在使用 postgres 数据库和 Java。我正在使用 Jooq 查询我的数据库。 我需要在我的表中插入并获取该插入生成的主键/序列。我知道在简单的 postgres 中我可以这样做:

这是我的表格的样子:

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;

但偏离路线最后一条语句给出了错误。

最佳答案

您的解决方案的问题是,当您向表中插入记录时,可能有另一个进程从序列中获取值,您将在第二个查询中得到错误的值 (SELECT currval).

PostgreSQL 允许您使用 RETURNING 子句在 INSERT 语句中取回一些数据:

INSERT INTO public.myTable(some_text)
VALUES ('myValue')
RETURNING id;

正如 jOOQ 手册所述,在这种情况下您应该使用 returningfetch。我不确定正确使用(我不熟悉 jOOQ),如下所示:

config.dsl().insertInto(Tables.myTable)
.set(Tables.myTable.myText, inputText)
.returning(Tables.myTable.id)
.fetch();

关于postgresql - 在 jooq 中使用 postgres currval(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39786409/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com