如何解决JPA问题@OneToMany-如何从数据库中获取特定对象?
我有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();
}
但是我从数据库中获得了所有系列。有人可以告诉我我在做什么错吗?我应该在请求中传递用户吗?
解决方法
您将获得 series ,因为您使用 findAll()查询了Series Repository。
如果要获取属于特定用户的 Series ,只需将userId传递给相应的方法,例如:
@Override
public List<Series> getSeriesByUserId(int userId) {
return seriesRepository.findByUserId(userId);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。