我正在嘗試保存一個通過 OneToMany 關系與“志愿者”對象相關的“用戶”對象。當我嘗試保存它時,它僅在我為這兩個對象提供主要 ID 時才有效。但是,我需要的是保存實體并讓數據庫通過 autoIncrement 指定 ID。我不確定我該怎么做,或者即使有可能。有效的 Json 映射:{ "id":8, "userName": "user8", "password": "pass1234", "volunteersId": 6, "volunteers": [{ "id":6, "committeesId": 2, "outreachDate": "2019-12-07", "usersId": 8 }]}我需要的 Json 映射(但不會工作):{ "userName": "user8", "password": "pass1234", "volunteersId": 6, "volunteers": [{ "committeesId": 2, "outreachDate": "2019-12-07", }]}所以我在想也許有一種方法可以連接外鍵,這樣我就不必顯式添加自動增量 ID(usersId、volunteersId)。用戶控制器:@Controllerpublic class UserController { @RequestMapping(value = "/v1/users", method = RequestMethod.POST) public ResponseEntity<Object> saveUsers( @RequestBody UserEntity request){ try { return ResponseEntity.ok(userService.saveUser(request)); } catch (Exception e) { e.printStackTrace(); return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build(); } }}用戶服務:@Servicepublic class UserService { @Autowired private UserRepository userRepository; public Page<UserEntity> saveUser(UserEntity user){ userRepository.save(user); Pageable pageable = PageRequest.of(0, 10, Sort.by("id").descending()); return userRepository.findAll(pageable); }}用戶存儲庫:public interface UserRepository extends JpaRepository<UserEntity, Long> { public List<UserEntity> findAllByOrderByIdAsc(); public List<UserEntity> findAllByOrderByIdDesc(); public Page<UserEntity> findByUserNameContaining(String userName, Pageable pageable);}
2 回答

墨色風雨
TA貢獻1853條經驗 獲得超6個贊
您需要在 @id 旁邊添加 @GeneratedValue 注釋
@Id
@GeneratedValue(strategy = GenerationType.selectOne)
private long id;
在序列的情況下,您需要添加一個額外的注釋
@Id
@SequenceGenerator(name = "customName", sequenceName = "sequenceNameInDatabase")
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator="customName")
private long id;

慕田峪9158850
TA貢獻1794條經驗 獲得超7個贊
這將使主 ID 生成自動
@Entity
@Table(name = "user")
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class User implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Long id;
添加回答
舉報
0/150
提交
取消