Как получить участников с jpa?

у меня есть эта сущность:

@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);

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

что это Meet?

Deadpool 21.05.2019 03:18

@Deadpool — это класс, это группа пользователей

user10150075 21.05.2019 03:25
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
Как вычислять биты и понимать побитовые операторы в Java - объяснение с примерами
В компьютерном программировании биты играют важнейшую роль в представлении и манипулировании данными на двоичном уровне. Побитовые операции...
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Поднятие тревоги для долго выполняющихся методов в Spring Boot
Приходилось ли вам сталкиваться с требованиями, в которых вас могли попросить поднять тревогу или выдать ошибку, когда метод Java занимает больше...
Полный курс Java для разработчиков веб-сайтов и приложений
Полный курс Java для разработчиков веб-сайтов и приложений
Получите сертификат Java Web и Application Developer, используя наш курс.
0
2
125
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Ответ принят как подходящий

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

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

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

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

@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<>();
}

это хорошая колонка ManyToOne (name = "meet_id")? Я думаю, что это должно быть onetoone?

user10150075 21.05.2019 03:50

Зависит от вашего отношения к объекту домена. Потому что я думал, что это @ManyToOne между Meet и Участником в вашем дизайне.

diorch 21.05.2019 03:57

Другие вопросы по теме