]> git.somenet.org - pub/jan/dst18.git/blob - ass1-jpa/src/main/java/dst/ass1/jpa/model/impl/Lecturer.java
[1.2.1c] another dreadful named query.
[pub/jan/dst18.git] / ass1-jpa / src / main / java / dst / ass1 / jpa / model / impl / Lecturer.java
1 package dst.ass1.jpa.model.impl;
2
3 import dst.ass1.jpa.model.ICourse;
4 import dst.ass1.jpa.model.ILecturer;
5 import dst.ass1.jpa.model.ILesson;
6 import dst.ass1.jpa.util.Constants;
7
8 import javax.persistence.*;
9 import java.util.ArrayList;
10 import java.util.Collection;
11
12 @Entity
13 @Table(name = Constants.T_LECTURER)
14 @PrimaryKeyJoinColumn(name = "id")
15 @NamedQuery(name = Constants.Q_MOST_ACTIVE_LECTURER, query = "SELECT l" +
16         " FROM " + Constants.T_LECTURER + " l" +
17         " WHERE size(l.lessons) >= ALL(" +
18         " SELECT size(le.lessons) FROM " + Constants.T_LECTURER + " as le GROUP BY le" +
19         " )")
20 public class Lecturer extends Person implements ILecturer {
21     @OneToMany(targetEntity = Course.class)
22     private Collection<ICourse> courses = new ArrayList<>();
23
24     @ManyToMany(targetEntity = Lesson.class)
25     @JoinTable(name = Constants.J_LECTURER_LESSON,
26             joinColumns = {
27                     @JoinColumn(name = Constants.I_LECTURER)
28             },
29             inverseJoinColumns = {
30                     @JoinColumn(name = Constants.I_LESSON)
31             })
32     private Collection<ILesson> lessons = new ArrayList<>();
33
34
35     @Override
36     public Collection<ICourse> getCourses() {
37         return courses;
38     }
39
40     @Override
41     public void setCourses(Collection<ICourse> courses) {
42         this.courses = courses;
43     }
44
45     @Override
46     public void addCourse(ICourse course) {
47         this.courses.add(course);
48     }
49
50     @Override
51     public Collection<ILesson> getLessons() {
52         return lessons;
53     }
54
55     @Override
56     public void setLessons(Collection<ILesson> lessons) {
57         this.lessons = lessons;
58     }
59
60     @Override
61     public void addLesson(ILesson lesson) {
62         this.lessons.add(lesson);
63     }
64 }