我试图使用以下代码来获取自动生成的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的返回查询
基础教程推荐
- Java JWT Token 2023-10-08
- Java算法比赛常用方法实例总结 2023-07-14
- java实现简单的学生管理系统 2022-11-01
- 详解hibernate自动创建表的配置 2023-07-31
- java – tomcat 7 JDBC连接池 – 每个数据库的独立池? 2023-11-06
- 排序算法图解之Java冒泡排序及优化 2023-07-01
- Java生成范围内随机整数的三种方法 2023-03-11
- 简单实现jsp分页 2023-08-02
- 使用Spring Boot+gRPC构建微服务并部署的案例详解 2023-02-10
- 使用MyBatis进行简单的更新与查询方式 2023-06-24