Как получить участников с jpa? - PullRequest
0 голосов
/ 21 мая 2019

У меня есть этот объект:

@Entity
@Table(name = "Participant")
public class Participant {

    @Column(name = "user")
    User user;

    @Column(name = "meet")
    Meet meet;

    @Enumerated(EnumType.STRING)
    @Column(name = "rol")
    Rol rol;

И класс Meet:

@Entity
@Table(name = "Meet")
public class Meet implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long id;

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

    @Enumerated(EnumType.STRING)
    @Column(name = "state")
    private State state;

Я хочу получить участие через встречу

@Query("SELECT p FROM Participant p where p.meet= :id")
    Participant findByMeet(@Param("id") Long id);

Как мне получитьсписок участников, которые входят в собрание

Ответы [ 2 ]

0 голосов
/ 21 мая 2019

Прежде всего, добавьте поля в модель домена.

@Entity 
@Table(name = "Participant")
public class Participant {

    @Column(name = "user")
    User user;

    @ManyToOne
    @Column(name = "meet_id") // It's a foreign key of Participant 
    Meet meet;

    @Enumerated(EnumType.STRING)
    @Column(name = "rol")
     Rol rol;
}

@Entity
@Table(name = "Meet")
public class Meet implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private long id;

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

    @Enumerated(EnumType.STRING)
    @Column(name = "state")
    private State state;

    @OneToMany(mappedBy = "Meet", cascade = CascadeType.ALL, orphanRemoval = true)
    private Set<Participant> participants = new HashSet<>();
}
0 голосов
/ 21 мая 2019

Если у вас @Id из Long в Participant, это должно быть что-то вроде этого.

@Repository
public interface ParticipantRepository implements CrudRepository<Participant, Long> {
  List<Participant> findAllByMeet(Meet meet);
}

Spring Data обеспечит вам динамическую реализацию.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...