Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
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 ");
}
}
}
user
является зарезервированным словом, и обычно не рекомендуется использовать зарезервированные слова для идентификаторов (таблицы, столбцы).
Если вы настаиваете на том, что вы должны поместить имя таблицы в двойное цитаты:
create table "user" (...);
Но тогда вам всегда нужно использовать двойные кавычки, ссылаясь на таблицу. Кроме того, имя таблицы затем учитывает регистр. "user"
- другое имя таблицы, чем "User"
.
Если вы хотите сэкономить много проблем, используйте другое имя. users
, user_account
, ...
Более подробную информацию о цитируемых идентификаторах можно найти в руководстве: http://www.postgresql.org/docs/current/static/sql -syntax-lexical.html # SQL-синтаксических ИДЕНТИФИКАТОРЫ
Можно указать имя таблицы с JPA со следующим синтаксисом:
@Table(name="\"user\"")