java - 保存对象后外键为空

标签 java hibernate

我在 Citizen 之间有一个关系:

@Entity
@Table(name = "citizens")
public class Citizen {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@Size(max = 10, min = 10, message = "CPR must be exactly 10 characters")
private String cpr;

@OneToMany(mappedBy = "citizen", cascade = CascadeType.ALL, orphanRemoval = true)
private List<WeeklyCare> weeklyCare;
}

WeeklyCare:

@Entity
public class WeeklyCare {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "citizen_id")
private Citizen citizen;
}

我有一个 REST API,它接收一个 Citizen 列表,每个列表都有一个 WeeklyCare 列表并保存它们:

@Autowired
private CitizenRepository citizenRepository;

@CrossOrigin(origins = "http://localhost:4200")
@PostMapping(path = "/add") // Map ONLY GET Requests
@Secured({"ROLE_ADMIN", "ROLE_DATAMANAGER"})
public ResponseEntity addNewCitizens(
        @RequestBody List<Citizen> citizens) {
    citizenRepository.saveAll(citizens);
    return new ResponseEntity(new ApiResponse(true, "Filen er blevet indlæst", "CITIZENS_SAVED"), HttpStatus.OK);
} 

在此之后,当我查看数据库中的 weekly_care 表时,citizen_id 列上的所有行都为空。我错过了什么?

最佳答案

这是 Hibernate 中的常见场景,是由于未设置关系的反转导致的:

Citizen c = new Citizen();
WeeklyCare w = new WeeklyCare();
c.getWeeklyCare().add(w);

//The missing link:
w.setCitizen(c);

citizenRepository.save(c);

虽然我不确定这是如何在您的网络服务请求中配置的...

关于java - 保存对象后外键为空,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55433706/

相关文章:

java - spring + hibernate配置错误?类路径资源 [spring.xml] 中的 XML 文档无效

java - 在psql中获取TEXT列值

java - 将方法限制为 RandomAccess 列表

hibernate - 关于 Hibernate 缓存机制的一些说明?

java - 向导式图像处理App架构

java - 正则表达式验证配置

java - 高质量语言。两个列表的交集

java - 当在 SQL 中用作别名时,将不存在的列存储在 JPA 实体中

java - 无法通过 JBoss AS 7 安全子系统进行身份验证

Java JEditorPane 格式