Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 06.09.2023
Сообщений: 9
SQLite

При добавлении пользователя выходит ошибка Cannot invoke "java.sql.Connection.prepareStatement(St­ring)" because "this.co

11.09.2023, 16:21. Показов 1537. Ответов 2

Студворк — интернет-сервис помощи студентам
Приветствую, делаю бд sqlite и при добавлении пользователя выходит ошибка Cannot invoke "java.sql.Connection.prepareStatement(St ring)" because "this.connection" is null

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
public class DataBaseHandler extends Const {
 
    private static final String DB_URL = "jdbc:sqlite:../db.db";
 
    private Connection connection;
 
    public DataBaseHandler() {
        try {
            // Загрузка драйвера JDBC для SQLite
            Class.forName("org.sqlite.JDBC");
        } catch (ClassNotFoundException e) {
            System.err.println("Не удалось загрузить драйвер JDBC");
            e.printStackTrace();
        }
    }
 
    public void connect() {
        try {
            // Подключение к базе данных
            connection = DriverManager.getConnection(DB_URL);
            System.out.println("Подключение к базе данных выполнено успешно!");
        } catch (SQLException e) {
            System.err.println("Не удалось подключиться к базе данных");
            e.printStackTrace();
        }
    }
 
    public void disconnect() {
        try {
            if (connection != null && !connection.isClosed()) {
                // Закрытие подключения
                connection.close();
                System.out.println("Отключение от базы данных выполнено успешно!");
            }
        } catch (SQLException e) {
            System.err.println("Не удалось отключиться от базы данных");
            e.printStackTrace();
        }
    }
 
    public Connection getConnection() {
        return connection;
    }
 
    public void addUser(String nikname, String login, String password) {
        String sql = "INSERT  INTO users (nikname, login, password) VALUES (?, ?, ?)";
        try (PreparedStatement statement = connection.prepareStatement(sql)) {
                statement.setString(1, nikname);
                statement.setString(2, login);
                statement.setString(3, password);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.09.2023, 16:21
Ответы с готовыми решениями:

При добавлении записи выходит ошибка
При добавлении записи выходит ошибка. Необработанное исключение типа "Finisar.SQLite.SQLiteException" произошло в...

При добавлении сессии в файл выходит ошибка
Что в этом коде не так ? Доблаяю сессию чтобы пользователь долго был активен на сайте, но выходит ошибка Warning: session_start():...

При добавлении utm-меток выходит ошибка 404
Собственно сабж, при добавлении utm-меток выходит ошибка 404. Если добавить в конец ?test, то все норм. Сама утм метка на других сайтах...

2
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
11.09.2023, 19:33
Ну хз. Арбайтен
Java
1
2
3
4
5
6
7
8
9
10
package ru.ismokejc;
 
public class Cyber {
    public static void main(String[] args) {
        DataBaseHandler handler = new DataBaseHandler();
        handler.connect();
        handler.addUser("user", "user", "password");
        handler.disconnect();
    }
}
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
package ru.ismokejc;
 
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
 
public class DataBaseHandler {
    private static final String DB_URL = "jdbc:sqlite:db.db";
 
    private Connection connection;
 
    public DataBaseHandler() {
        try {
//             Загрузка драйвера JDBC для SQLite
            Class.forName("org.sqlite.JDBC");
        } catch (ClassNotFoundException e) {
            System.err.println("Не удалось загрузить драйвер JDBC");
            e.printStackTrace();
        }
    }
 
    public void connect() {
        try {
            // Подключение к базе данных
            connection = DriverManager.getConnection(DB_URL);
            System.out.println("Подключение к базе данных выполнено успешно!");
            connection.setAutoCommit(false);
        } catch (SQLException e) {
            System.err.println("Не удалось подключиться к базе данных");
            e.printStackTrace();
        }
    }
 
    public void disconnect() {
        try {
            if (connection != null && !connection.isClosed()) {
                // Закрытие подключения
                connection.close();
                System.out.println("Отключение от базы данных выполнено успешно!");
            }
        } catch (SQLException e) {
            System.err.println("Не удалось отключиться от базы данных");
            e.printStackTrace();
        }
    }
 
    public void addUser(String nikname, String login, String password) {
        String sql = "INSERT  INTO users (nikname, login, password) VALUES (?, ?, ?)";
        try (PreparedStatement statement = connection.prepareStatement(sql)) {
            statement.setString(1, nikname);
            statement.setString(2, login);
            statement.setString(3, password);
            statement.executeUpdate();
            connection.commit();
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }
}
1
0 / 0 / 0
Регистрация: 06.09.2023
Сообщений: 9
12.09.2023, 03:46  [ТС]
спасибо, без тебя я наверное еще сидел бы и не замечал, что я забыл к бд приконектится, это меня скоро доведет
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.09.2023, 03:46
Помогаю со студенческими работами здесь

Правила обновления SQL: не работает обновление при добавлении нового пользователя
Форумчане) Проблема одна с обновлением при добавлении нового пользователя)

При нажатии на кнопку выходит ошибка "Attempting to invoke method on a null object reference"
Доброго дня! Есть вот этот код. При нажатии на кнопку Add выдает Attempting to invoke interface method java.sql.Statement...

Ошибка при добавлении базы данных (при коннектинге "Add Connection")
Здравствуйте, возникла проблема при коннектинге базы данных. После того как хочу создать новую базу данных выходит следующая ошибка: a...

ошибка при создании приложения Exception in thread "main" java.lang.NullPointerException: Cannot invoke "java.net.URL.to
Ошибка: C:\Users\kozna\.jdks\openjdk-16\bin\java.exe "-javaagent:D:\IntelliJ IDEA Community Edition...

Ошибка при добавлении пользователя в базу данных
ОШИБКА: столбец "updated_at" в таблице "users" не существует. Laravel 8.83.26 База данных: Schema::create('users', function...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru