Использование Spring-Mybatis для получения столбцов из неизвестной таблицы [duplicate]

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

Например, ниже - класс ученика, который будет использовать его в нашем коде.

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 ");
        }
    }
}
4
задан Landys 24 February 2015 в 07:59
поделиться

1 ответ

${} не поддерживает индекс параметра в соответствии с моим тестом. Вы можете использовать аннотацию 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 .

4
ответ дан indivisible 18 August 2018 в 05:03
поделиться
  • 1
    Это помогло мне понять, что в моем случае мне нужно было заменить '# {' на '$ {': первый для MyBatis должен создать параметр PreparedStatement, а последний - для простой инъекции строк. См. «Замена строк». раздел в mybatis.org/mybatis-3/sqlmap-xml.html – cellepo 16 December 2016 в 00:39
  • 2
    ^ Очень важно указать разницу между синтаксисом $ {...} и # {...}. Один из них - SQL Injection safe (#), а другой NOT ($), – indivisible 14 February 2017 в 16:51
Другие вопросы по тегам:

Похожие вопросы: