我将 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/