gpt4 book ai didi

java - JPA使用auto_increment主键覆盖记录

转载 作者:行者123 更新时间:2023-11-29 16:44:17 25 4
gpt4 key购买 nike

我已经搜索过,但没有找到任何适合我的信息。我有一个像这样的实体类,亲爱的:

@Entity
public class Report {
@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "id")
private int id;
@Column(name = "descrizione")
private String descrizione = null;

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

public String getDescrizione() {
return descrizione;
}

public void setDescrizione(String descrizione) {
this.descrizione = descrizione;
}
}

并使用 auto_increment pk 将表放入 mysql 数据库中。但我不知道为什么 auto_increment 仅在启动 Web 服务时才起作用。之后,hibernate 只是覆盖最后一条记录,而不使用自动递增主键创建新记录。

进入 application.properties 我有这样的配置:

spring.jpa.hibernate.ddl-auto=none
spring.datasource.url=jdbc:mysql://localhost:3306/civicsense?serverTimezone=UTC
spring.datasource.username=root
spring.datasource.password=AAAAAAA

一些帮助将不胜感激

最佳答案

首先,将 int 更改为 Long。并且您可以省略该策略,因为对于 MySQL,GenerationType.IDENTITYGenerationType.AUTO 相同,相当于仅添加 @GenerateValue

@Id @GeneratedValue
private Long id;

此外,您的问题可能是您添加实体的方式。在这种情况下,您可能需要使用 saveAndFlush() ,因为在此命令中更改将立即刷新到数据库,这可能会阻止您的问题,因为您的实际方法可能不会按时提交。

关于java - JPA使用auto_increment主键覆盖记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53173814/

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