0
I’m learning the Spring framework, I tried to follow some 1-1 relationship tutorials where a library has an address. When uploading library data and address id in the body, a new record is inserted in the library table, but the address_id
that references an address is not entered, even passing the request payload.
My model Library:
@Entity
@Table(name = "Bibliotecas")
public class Library implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;
private String name;
@OneToOne
@JoinColumn(name = "address_id", referencedColumnName = "id")
private Address address;
public Library() {
}
public long getId() {
return this.id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public Address getAddress() {
return this.address;
}
public void setAddress(Address address) {
this.address = address;
}
}
My model Address:
@Entity
public class Address {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private long id;
@Column(nullable = false)
private String location;
public long getId() {
return this.id;
}
public void setId(long id) {
this.id = id;
}
public String getLocation() {
return this.location;
}
public void setLocation(String location) {
this.location = location;
}
@OneToOne(mappedBy = "address", fetch = FetchType.LAZY, optional = false)
private Library library;
}
Mine repositories:
public interface LibraryRepository extends JpaRepository<Library, Long> {}
public interface AddressRepository extends JpaRepository<Address, Long> {}
My library Resource:
@RestController
@RequestMapping(value = "/api")
public class LibraryResource {
@Autowired
LibraryRepository libraryRepository;
@GetMapping("/libraries")
public List<Library> listaBibliotecas() {
return libraryRepository.findAll();
}
@PostMapping("/library")
public Library salvaBiblioteca(@RequestBody Library library) {
return libraryRepository.save(library);
}
}
And then I pass on my request:
{
"name": "Biblioteca test",
"address_id": 1
}
Note: There is an address with id
1, I get return:
{
"id": 5,
"name": "Biblioteca test",
"address": null
}
In my return address is null, and when I give a select in the database, the created record has address_id null. How can I correct the link between these two models? Because this is happening?
It worked that way, @rafaelchagasb, thank you. Can you tell me why Location returns null even when the related record has data in the Location column?
– veroneseComS
save will not return the object of your relationship in a managed way. It will return the data you send to it. In this case here, it will try to make the relationship with the id 1 Adress and will return the object with the other properties you sent. { "name": "Library test", "address": { "id":"1", "Location": "object" } } .
– Rafael Chagas