我有 User
和 Series
实体。用户有系列列表。
public class User {
@Id
@GeneratedValue
private int id;
private String userName;
private String password;
@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true)
@JoinColumn(name = "user_id")
private List<Series> series = new ArrayList<>();
}
@Data
@NoArgsConstructor
@AllArgsConstructor
@Entity
@Table(name="series")
public class Series {
@Id
@GeneratedValue
private int id;
private String name;
private String year;
private String photo; //as an url
private String description;
private float totalScore;
private float score;
User user;
}
我想获取分配给特定用户的系列。 在系列服务中,我执行以下操作来获取系列:
@Override
public List<Series> getAllSeries() {
return seriesRepository.findAll();
}
但是我从数据库中获取了所有系列。有人可以告诉我我做错了什么吗?我应该在请求中传递用户吗?
最佳答案
您将获得系列,因为您使用findAll()查询系列存储库。
如果你想获取属于特定用户的Series,只需将userId传递给相应的方法即可,例如:
@Override
public List<Series> getSeriesByUserId(int userId) {
return seriesRepository.findByUserId(userId);
}
关于java - JPA问题@OneToMany - 如何从数据库获取特定对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63549133/