如何在 spring boot 中使用 CrudRepository 检索基于反列数据的数据?

How to retrieve data based on inverseColumn data using CrudRepository in springboot?

我有两个 table,即用户和事件。用户 table 将在新用户注册时填写。稍后同一用户可以创建日历事件。因此事件 table 将被填充并且 users_events 将保持基于用户的事件映射。 我想根据登录的 userId 查找所有事件。所以这里是查询,它应该 return 基于它的数据。 select * 来自 eventid in (select eventId from users_event where id_user=x ) 的事件。这是我的用户和事件实体 class.

User.java

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

@Id
@GenericGenerator(name = "generator", strategy = "increment")
@GeneratedValue(generator = "generator")
@Column(name = "id", nullable = false)
private Long id;

@Column(name = "first_name", nullable = false)
private String firstName;

@Column(name = "family_name", nullable = false)
private String familyName;

@Column(name = "e_mail", nullable = false)
private String email;

@Column(name = "phone", nullable = false)
private String phone;

@Column(name = "language", nullable = false)
private String language;

@Column(name = "id_picture")
private String pictureId;

@Column(name = "login", nullable = false)
private String login;

@Column(name = "password", nullable = false)
private String password;

@Column(name = "birth_date")
private Date birthDate;

@Column(name = "enabled")
private Boolean enabled;
   //getter and setter

Event.java

    @Entity
    @Table(name = "events")
    public class Event {
@Id
@GenericGenerator(name = "generator", strategy = "increment")
@GeneratedValue(generator = "generator")
@Column(name = "eventId", nullable = false)
private Long eventId;

@Column(name = "title", nullable = false)
private String title;

@Column(name = "description", nullable = true)
private String description;

@Column(name = "startAt", nullable = false)
@Temporal(TemporalType.TIMESTAMP)
private Date startAt;

@Column(name = "endAt", nullable = true)
@Temporal(TemporalType.TIMESTAMP)
private Date endAt;

@Column(name = "isFullDay", nullable = false)
private Boolean isFullDay;

@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(name = "users_event", joinColumns = { @JoinColumn(name = "id_event", referencedColumnName = "eventId") }, inverseJoinColumns = { @JoinColumn(name = "id_user", table = "users", referencedColumnName = "id") })
private Set<User> user = new HashSet<User>();
/getter and setter

EventRepo.java

   public interface EventRepo extends CrudRepository<Event, Long> {
Event findByUser(Set<User> user);
    }

我正在尝试实现一些东西,它可以给我这个查询的输出。 select * 来自 eventid in (select eventId from users_event where id_user=x ) 的事件 这是我的 implementation.any 输入吗?

       @RequestMapping(value = "/events", method = RequestMethod.GET)
public @ResponseBody List<Event> getEvents() {
    logger.debug("get event list");
    User x=new User();
    x.setId(1);
    Set<User> user= new HashSet();
    user.add(x);
    return (List<Event>) eventRepo.findByUser(user);
}

只需将以下方法添加到您的 EventRepo:

List<Event> findAllByUserId(Long userId);

并将您的控制器修改为如下所示:

@RequestMapping(value = "/events", method = RequestMethod.GET)
public List<Event> getEvents() {
    return eventRepo.findAllByUserId(1L);
}