Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
public class Student {
private int id;
public int getId() {
return this.id;
}
public setId(int newId) {
this.id = newId;
}
}
Приведенный ниже код дает вам исключение с нулевым указателем.
public class School {
Student obj_Student;
public School() {
try {
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Поскольку вы используете Obj_Student
, но вы забыли инициализировать его, как в правильном коде, показанном ниже:
public class School {
Student obj_Student;
public School() {
try {
obj_Student = new Student();
obj_Student.setId(12);
obj_Student.getId();
}
catch(Exception e) {
System.out.println("Null Pointer ");
}
}
}
Чтобы получить общее представление о том, сколько студентов обучаются на курсах с младшим преподавателем:
SELECT t.id, count(distinct s.id) filter (WHERE s.age > t.age)
FROM teacher t
JOIN course c ON (t.id = c.course_teacher)
JOIN enrolment e ON (e.course = c.id)
JOIN student s ON (s.id = e.student)
GROUP BY 1;
... предоставит что-то вроде:
id | count
----+-------
1 | 3
2 | 1
3 | 0
...
Если вы хотите больше понимание, просто добавьте к нему курс, например:
SELECT t.id, t.name, c.id, c.title, count(s.*) filter (WHERE s.age > t.age)
FROM teacher t
JOIN course c ON (t.id = c.course_teacher)
JOIN enrolment e ON (e.course = c.id)
JOIN student s ON (s.id = e.student)
GROUP BY 1, 2, 3, 4;
... в результате:
id | name | id | title | count
----+------------------+----+---------+-------
1 | Donata Barna | 1 | Maths | 3
3 | Katsurou Plourde | 3 | History | 0
2 | Natela Kardos | 2 | Physics | 1
...
... и если вам нужно знать, какие студенты старше их учитель, в котором курс (ы), используйте это:
SELECT s.id, s.name, array_agg(c.title) filter (WHERE s.age > t.age)
FROM teacher t
JOIN course c ON (t.id = c.course_teacher)
JOIN enrolment e ON (e.course = c.id)
JOIN student s ON (s.id = e.student)
GROUP BY 1 ORDER BY 1;
... в результате:
id | name | array_agg
----+------------------+-----------------
1 | Oda Peters |
2 | Lourens Strand | {Maths,Physics}
3 | Haf Giannopoulos | {Maths}
4 | Fuat Nervi | {Maths}
5 | Hadil Giffard |
...
Используемые тестовые данные:
INSERT INTO teacher (id, name, age) VALUES
(1, 'Donata Barna', 25),
(2, 'Natela Kardos', 31),
(3, 'Katsurou Plourde', 53)
;
INSERT INTO student (id, name, age) VALUES
(1, 'Oda Peters', 19),
(2, 'Lourens Strand', 32),
(3, 'Haf Giannopoulos', 29),
(4, 'Fuat Nervi', 26),
(5, 'Hadil Giffard', 25)
;
INSERT INTO course (id, title, course_teacher) VALUES
(1, 'Maths', 1),
(2, 'Physics', 2),
(3, 'History', 3)
;
INSERT INTO enrolment (course, student)
SELECT c.id AS course, s.id AS student
FROM generate_series(1,3) AS c(id)
CROSS JOIN generate_series(1,5) AS s(id);