我试图使用以下代码来获取自动生成的ID.我的后端是MySQL.代码看起来像这样Record record = create.insertInto(CANDIDATE, CANDIDATE.FIRST_NAME, CANDIDATE.LAST_NAME,CANDIDATE.EXTRACTED_NAME).values(Charl...
我试图使用以下代码来获取自动生成的ID.我的后端是MySQL.代码看起来像这样
Record record = create.insertInto(CANDIDATE, CANDIDATE.FIRST_NAME,
CANDIDATE.LAST_NAME,CANDIDATE.EXTRACTED_NAME)
.values("Charlotte", "Roche","Charlotte Roche")
.returning(CANDIDATE.ID)
.fetchOne();
System.out.println(record.getValue(CANDIDATE.ID));
我收到了NullPointerException.我看了一眼http://www.jooq.org/javadoc/latest/org/jooq/InsertReturningStep.html.
它说
Derby, H2, Ingres, MySQL, SQL Server only allow for retrieving IDENTITY column values as “generated key”. If other fields are requested, a second statement is issued. Client code must assure transactional integrity between the two statements.
根据我在Mysql中的理解,auto_increment可以作为IDENTITY使用.请问有谁可以说明如何为MySQL实现这一目标
我看过这个SO Question on a similar topic并尝试了以下
Result<?> record =
create.insertInto(CANDIDATE, CANDIDATE.FIRST_NAME, CANDIDATE.LAST_NAME,CANDIDATE.EXTRACTED_NAME)
.values("Charlotte", "Roche","Charlotte Roche")
.returning(CANDIDATE.ID)
.fetch();
System.out.println(record.size());
虽然它在后端插入记录但它将record.size()打印为零
解决方法:
我知道我迟到了.
但我希望我能帮助有类似问题的人,
Derby, H2, Ingres, MySQL, SQL Server only allow for retrieving IDENTITY column values as “generated key“. If other fields are requested, a second statement is issued. Client code must assure transactional integrity between the two statements.
“生成密钥”这个词就是问题所在.
您可以使用SHOW CREATE TABLE $table_name检查您的表ID是否为AUTO_INCREMENT.我认为不是.
P / s:我正在使用MySQL
本文标题为:java – 在JOOQ中插入MySQL的返回查询
基础教程推荐
- SpringBoot+JSON+AJAX+ECharts+Fiddler实现前后端分离开发可视化 2023-01-24
- Java多线程并发与并行和线程与进程案例 2023-01-08
- Java实现双向链表 2022-11-11
- Java利用EasyExcel实现合并单元格 2022-12-19
- 用法介绍Java Observer模式 2023-10-08
- 如何在SpringBoot项目里进行统一异常处理 2023-03-21
- springboot整合redis之消息队列 2023-02-10
- SpringBoot如何获取Kafka的Topic列表 2023-06-05
- java 集合工具类Collections及Comparable和Comparator排序详解 2023-01-08
- Spring 事务隔离与事务传播的详解与对比 2023-07-31
