Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.
Например, ниже - класс ученика, который будет использовать его в нашем коде.
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 ");
}
}
}
${}
не поддерживает индекс параметра в соответствии с моим тестом. Вы можете использовать аннотацию Param
, чтобы указать имя параметра в объявлении API-интерфейса mapper.
public MatchResult get(long id, @Param("tablename") String tablename);
Mapper xml:
<select id="get" resultType="myresult">
select * from ${tabelname} where id=#{0}
</select>
Альтернативой является использование объекта вашего собственный класс или карту в качестве параметра, если вы не хотите, чтобы конкретная аннотация IBatis/MyBatis
Param
в вашем объявлении API-интерфейса mapper.
Возьмите карту в качестве примера, ваш java API может быть:
public MatchResult get(Map<String, Object> params);
Операторы xper-оператора mapper могут быть:
<select id="get" parameterType="map" resultType="myresult">
select * from ${tablename} where id=#{id}
</select>
И поместите идентификатор и имя таблицы на карту с помощью ключа «id» и «tablename» перед вызовом API .