亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何使用相關的自動遞增 ID 保存具有 OneToMany 關系的實體

如何使用相關的自動遞增 ID 保存具有 OneToMany 關系的實體

狐的傳說 2022-12-21 16:44:05
我正在嘗試保存一個通過 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;


查看完整回答
反對 回復 2022-12-21
?
慕田峪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;


查看完整回答
反對 回復 2022-12-21
  • 2 回答
  • 0 關注
  • 111 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號