Внешний ключ является нулевым после сохранения объектов - PullRequest
3 голосов
/ 30 марта 2019

У меня есть отношения между 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 в базе данных, все столбцы имеют значение NULL в столбце citizen_id. Чего мне не хватает?

1 Ответ

2 голосов
/ 30 марта 2019

Это распространенный сценарий в Hibernate, в результате которого не устанавливается обратная связь:

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

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

citizenRepository.save(c);

Хотя я не уверен, как это настроено в вашем запросе веб-службы ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...