繁体   English   中英

如何在不获取关联对象的情况下将实体持久存储在Spring Data JPA中

[英]How to persist an entity in Spring Data JPA without getting associated objects

假设我有2个实体

    @Entity
    @Table(name = "users")
    public class User implements Serializable {

        private User() {

        }

    ... other fields omitted ...

        @OneToMany(mappedBy = "user")
        private List<Car> cars;

    }

@Entity
@Table(name = "cars")
public class Car implements Serializable {

    public Car() {

    }

... Other fields omitted ...

    @Column(name = "id")
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;

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

}

现在,每当我在CarRepository上调用save时,它都要求我在用户字段上有一个User对象。 这样,我仍然需要像我的UserRepository中那样调用findById方法

...
car.setUser(userRepository.findById(userId));
carRepository.save(car);
...

Spring Data JPA是否有一种方法可以仅使用userId进行保存,而在持久保存car对象之前我不必获取用户对象?

您可以尝试创建User对象并在其中设置userId并将其设置在car对象中。

User existingUser = new User();
existingUser.setId(userId);
car.setUser(existingUser);
carRepository.save(car);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM