繁体   English   中英

JPA 问题@OneToMany - 如何从数据库中获取特定对象?

[英]JPA problem @OneToMany - how to get particular objects from database?

我有UserSeries实体。 用户有系列列表。

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 ,只需将 userId 传递给相应的方法,例如:

@Override
public List<Series> getSeriesByUserId(int userId) {
   return seriesRepository.findByUserId(userId);
}

暂无
暂无

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

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