Хобрук: Ваш путь к мастерству в программировании

Как установитьFloat значение PreparedStatement (jdbc) на NULL

Я хочу вставить в свою базу данных много данных с помощью программы Java. Я пытаюсь справиться с тем фактом, что значение String может быть пустым, таким образом, я хочу установить значение null.

Это не работает (pstm.setFloat...):

PreparedStatement pstm;
try {
    pstm = connex.prepareStatement("INSERT INTO opfofa._produit_val_nut VALUES (?,?,?,?,?,?,?,?,?,?)");
    pstm.setInt(1,id);
    pstm.setString(2,tabChaine[8]);
    pstm.setFloat(3,tabChaine[9].isEmpty()? null:Float.valueOf(tabChaine[9]));
    ...
    pstm.executeUpdate();
}catch(PSQLException e) {
    System.out.println("already inserted : "+e);
}

Ошибка: java.lang.NullPointerException, и это нормально, потому что мы не можем установить для числа с плавающей запятой значение null, но в PostgreSQL я могу установить для числового столбца значение null.

Как я могу это сделать?


  • Вам нужно использовать setNull() 03.01.2018

Ответы:


1

setFloat выдает NullPointerException, потому что ожидает примитив float, а не объект Float. Вы можете попробовать использовать setObject вместо этого позволяет использовать null значений, если это необходимо. Что-то типа:

pstm.setObject(3, tabChaine[9].isEmpty() ? null : Float.valueOf(tabChaine[9]), java.sql.Types.FLOAT);
02.01.2018
  • Это работает, спасибо! 03.01.2018

  • 2

    Код должен выглядеть примерно так:

    PreparedStatement pstm;
    try {
        pstm = connex.prepareStatement("INSERT INTO opfofa._produit_val_nut VALUES (?,?,?,?,?,?,?,?,?,?)");
        pstm.setInt(1,id);
        pstm.setString(2,tabChaine[8]);
        if (tabChaine[9].isEmpty()) {
            pstm.setNull(3, java.sql.Types.FLOAT);
        }
        else {
            pstm.setFloat(3,Float.valueOf(tabChaine[9]));
        }
        ...
        pstm.executeUpdate();
    }catch(PSQLException e) {
        System.out.println("already inserted : "+e);
    }
    

    Дополнительная информация о setNull ()

    02.01.2018
  • Это тоже работает, спасибо большое! 03.01.2018

  • 3

    Вы должны использовать setNull(), если вам нужно установить нулевой параметр

    02.01.2018
    Новые материалы

    Создание кнопочного меню с использованием HTML, CSS и JavaScript
    Вы будете создавать кнопочное меню, которое имеет состояние наведения, а также позволяет вам выбирать кнопку при нажатии на нее. Финальный проект можно увидеть в этом Codepen . Шаг 1..

    Внедрите OAuth в свои веб-приложения для повышения безопасности
    OAuth — это широко распространенный стандарт авторизации, который позволяет приложениям получать доступ к ресурсам от имени пользователя, не раскрывая его пароль. Это позволяет пользователям..

    Классы в JavaScript
    class является образцом java Script Object. Конструкция «class» позволяет определять классы на основе прототипов с чистым, красивым синтаксисом. // define class Human class Human {..

    Как свинг-трейдеры могут использовать ИИ для больших выигрышей
    По мере того как все больше и больше профессиональных трейдеров и активных розничных трейдеров узнают о возможностях, которые предоставляет искусственный интеллект и машинное обучение для улучшения..

    Как построить любой стол
    Я разработчик программного обеспечения. Я люблю делать вещи и всегда любил. Для меня программирование всегда было способом создавать вещи, используя только компьютер и мое воображение...

    Обзор: Машинное обучение: классификация
    Только что закончил третий курс курса 4 часть специализации по машинному обучению . Как и второй курс, он был посвящен низкоуровневой работе алгоритмов машинного обучения. Что касается..

    Разработка расширений Qlik Sense с qExt
    Использование современных инструментов веб-разработки для разработки крутых расширений Вы когда-нибудь хотели кнопку для установки переменной в приложении Qlik Sense? Когда-нибудь просили..