Один и многие отношения, обновление данных в Spring Boot не работаетJAVA

Программисты JAVA общаются здесь
Anonymous
Один и многие отношения, обновление данных в Spring Boot не работает

Сообщение Anonymous »

iam Наивный пользователь, работающий над Spring Boot., Создавая отношения с OttoMany с пользователем (родитель) -> Адрес (ребенок). < /p>
Пост работает (создание пользователя работает ) < /p>
Невозможно обновить запись пользователя на почте, попытался искать в Интернете, но ни одно из решений не сработало для меня. < /p>
Вот мой код < /p>
User.java

@Entity
public class User {

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

private String name;
// @JsonIgnore
@JsonManagedReference
@OneToMany(mappedBy = "user", cascade = CascadeType.ALL, orphanRemoval = true)
private List addresses;

// Getters and setters
}

@Entity
public class Address {

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

private String street;
private String city;
private String state;
private String zip;

@JsonBackReference
@ManyToOne
@JoinColumn(name = "user_id")
private User user;

// Getters and setters
}

UserController.java

@PutMapping("/{id}")
public User updateUser(@PathVariable Long id, @RequestBody User user) {
User existingUser = userService.getUser(id);
existingUser.setName(user.getName());
existingUser.setAddresses(user.getAddresses());
return userService.updateUser(existingUser);
}

userService.java

public User updateUser(User user) {
return userRepository.save(user);
}

**OutPut**

org.hibernate.TransientObjectException: persistent instance references an unsaved transient instance of 'com.clt.product_service.entity.User' (save the transient instance before flushing)
at org.hibernate.engine.spi.CascadingActions$9.cascade(CascadingActions.java:382) ~[hibernate-core-6.6.4.Final.jar:6.6.4.Final]
at org.hibernate.engine.spi.CascadingActions$9.cascade(CascadingActions.java:372) ~[hibernate-core-6.6.4.Final.jar:6.6.4.Final]
at org.hibernate.engine.internal.Cascade.cascadeToOne(Cascade.java:570) ~[hibernate-core-6.6.4.Final.jar:6.6.4.Final]
at org.hibernate.engine.internal.Cascade.cascadeAssociation(Cascade.java:492) ~[hibernate-core-6.6.4.Final.jar:6.6.4.Final]
< /code>
почтальон - вывод < /p>
"timestamp": "2025-02-20T20:35:11.402+00:00",
"status": 500,
"error": "Internal Server Error",
"trace": "org.springframework.dao.InvalidDataAccessApiUsageException: org.hibernate.TransientObjectException: persistent instance references an unsaved transient instance of 'com.clt.product_service.entity.User' (save the transient instance before flushing)\r\n\tat org.springframework.orm.jpa.EntityManagerFactoryUtils.convertJpaAccessExceptionIfPossible(EntityManagerFactoryUtils.java:368)\r\n\tat org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:246)\r\n\tat org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.


Подробнее здесь: https://stackoverflow.com/questions/794 ... ot-working

Вернуться в «JAVA»