gpt4 book ai didi

java - 带有返回生成键的 jOOQ 插入查询

转载 作者:可可西里 更新时间:2023-11-01 06:31:57 25 4
gpt4 key购买 nike

我将 jOOQ 安装到 eclipse 中,为我的 mySQL 生成了类,但我仍然无法编写一些基本查询。

我试图通过返回生成的键来组合插入查询,但编译器抛出错误

表:tblCategory列:category_id, parent_id, name, rem, uipos

Result<TblcategoryRecord> result= create.insertInto(Tblcategory.TBLCATEGORY, 
Tblcategory.PARENT_ID, Tblcategory.NAME, Tblcategory.REM, Tblcategory.UIPOS)
.values(node.getParentid())
.values(node.getName())
.values(node.getRem())
.values(node.getUipos())
.returning(Tblcategory.CATEGORY_ID)
.fetch();

还尝试了其他不同的方式如何以正确的方式做到这一点?

谢谢魅力

最佳答案

您使用的语法用于插入多条记录。这将插入 4 条记录,每条记录有一个字段。

.values(node.getParentid())
.values(node.getName())
.values(node.getRem())
.values(node.getUipos())

但是你声明了 4 个字段,所以那是行不通的:

create.insertInto(Tblcategory.TBLCATEGORY, 
Tblcategory.PARENT_ID, Tblcategory.NAME, Tblcategory.REM, Tblcategory.UIPOS)

您可能想要做的是:

Result<TblcategoryRecord> result = create
.insertInto(Tblcategory.TBLCATEGORY,
Tblcategory.PARENT_ID, Tblcategory.NAME, Tblcategory.REM, Tblcategory.UIPOS)
.values(node.getParentid(), node.getName(), node.getRem(), node.getUipos())
.returning(Tblcategory.CATEGORY_ID)
.fetch();

或者:

Result<TblcategoryRecord> result = create
.insertInto(Tblcategory.TBLCATEGORY)
.set(Tblcategory.PARENT_ID, node.getParentid())
.set(Tblcategory.NAME, node.getName())
.set(Tblcategory.REM, node.getRem())
.set(Tblcategory.UIPOS, node.getUipos())
.returning(Tblcategory.CATEGORY_ID)
.fetch();

使用

可能你会过得更好
TblcategoryRecord result =
// [...]
.fetchOne();

有关更多详细信息,请参阅手册:

http://www.jooq.org/doc/2.6/manual/sql-building/sql-statements/insert-statement/

或者用于创建返回值的 INSERT 语句的 Javadoc:

http://www.jooq.org/javadoc/latest/org/jooq/InsertReturningStep.html

关于java - 带有返回生成键的 jOOQ 插入查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8127378/

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