【发布时间】:2019-07-27 03:29:40
【问题描述】:
我有一个 OneToMany 关系(用户到电子邮件地址)
也许我做错了,我的数据库是空的,但是如果我想发布一个用户对象并将其添加到数据库中,连同 emailAdresses 对象并保留 EmailAddress 。
我想要数据库中的 2 条记录: 1 个用户和 1 个电子邮件地址(带有一个指向用户表的 fk)
服务类
目前我为使其工作而实施的是:
@Service
public class UserService {
private UserRepository userRepository;
private ModelMapper modelMapper;
public UserService(UserRepository userRepository, ModelMapper modelMapper) {
this.userRepository = userRepository;
this.modelMapper = modelMapper;
//Used for mapping List
modelMapper.getConfiguration()
.setFieldMatchingEnabled(true)
.setFieldAccessLevel(Configuration.AccessLevel.PRIVATE)
.setSourceNamingConvention(NamingConventions.JAVABEANS_MUTATOR);
}
public User createUser(UserCreateDTO userCreateDTO) {
User user = modelMapper.map(userCreateDTO, User.class);
//persist User to EmailAddress object
if(user.getEmailAddresses() != null){
user.getEmailAddresses().forEach(user::persistUser);
}
return userRepository.save(user);
}
public UserDTO getUserById(Long id) {
User found = userRepository.findById(id).get();
return modelMapper.map(found, UserDTO.class);
}
// .....
我见过在一些双向关系中使用的
用户实体
@Entity
@Table(name = "Users")
@Getter @Setter @ToString @NoArgsConstructor
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "user_id", updatable = false, nullable = false)
private Long id;
private String firstName;
private String lastName;
private int age;
@OneToMany(fetch = FetchType.LAZY, mappedBy = "user", cascade = CascadeType.ALL, orphanRemoval = true)
private List<EmailAddress> emailAddresses;
电子邮件地址实体
@Entity
@Table(name = "Email")
@Getter @Setter @ToString @NoArgsConstructor
public class EmailAddress {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="email_id", updatable = false, nullable = false)
private Long emailId;
private String email;
@ManyToOne(fetch = FetchType.LAZY, cascade = CascadeType.PERSIST )
@JoinColumn(name = "user_id", nullable = false)
@JsonIgnore
private User user;
有没有更好的方法来建立 Join 关系?
POST 请求示例
{"firstName":"Joe", "lastName":"Bloggs", "age": 30, "emailAddresses" : [ "joe-private@email.com" , "joe-work@email.com" ] }
【问题讨论】:
-
你是持久化用户还是检索用户?您可以在实际调用 entityManager 或 Spring 存储库的位置添加服务类吗?
-
我认为 this question 几乎可以复制到你的。
标签: postgresql hibernate spring-boot jpa spring-data