При работе с базами данных в Java, использование
PreparedStatement является предпочтительным методом по сравнению с обычным Statement. Это связано с тем, что PreparedStatement помогает предотвратить SQL-инъекции и улучшает производительность за счет предварительной компиляции SQL-запросов.Пример использования PreparedStatement
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.SQLException;
public class JdbcPreparedStatementExample {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3000/mydatabase";
String user = "username";
String password = "password";
String sql = "INSERT INTO users (username, password) VALUES (?, ?)";
try (Connection conn = DriverManager.getConnection(url, user, password);
PreparedStatement pstmt = conn.prepareStatement(sql)) {
pstmt.setString(1, "newuser");
pstmt.setString(2, "securepassword");
pstmt.executeUpdate();
System.out.println("User added successfully!");
} catch (SQLException e) {
e.printStackTrace();
}
}
}
Использование
PreparedStatement не только защищает ваше приложение от SQL-инъекций, но и улучшает читаемость кода. Это особенно важно при работе с пользовательскими данными.Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🔥2
Please open Telegram to view this post
VIEW IN TELEGRAM
😁3
Please open Telegram to view this post
VIEW IN TELEGRAM
😁3
Please open Telegram to view this post
VIEW IN TELEGRAM
😁2
Разберём принципиальные различия между низкоуровневым JDBC и ORM-подходом JPA.
Connection conn = DriverManager.getConnection(url, user, pass);
Statement stmt = conn.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM users");
while (rs.next()) {
String name = rs.getString("name");
// ручное преобразование
}
Характеристики:
- Низкоуровневый API для SQL-запросов
- Требует ручного управления соединениями
- Необходимо вручную преобразовывать ResultSet в объекты
@Entity
public class User {
@Id
private Long id;
private String name;
// геттеры/сеттеры
}
// Использование:
User user = entityManager.find(User.class, 1L);
- Высокоуровневая абстракция (ORM)
- Работа с объектами вместо SQL
- Автоматическое управление сессиями
- Кеширование, ленивая загрузка
▫️ Уровень абстракции
JDBC: SQL-ориентированный
JPA: Объектно-ориентированный
▫️ Преобразование данных
JDBC: Ручное
JPA: Автоматическое
▫️ Производительность
JDBC: Выше
JPA: Может быть ниже из-за накладных расходов
▫️ Код
JDBC: Больше boilerplate
JPA: Лаконичнее
▫️ Портативность
JDBC: Зависит от SQL диалекта
JPA: Независимость от БД
Резюмируем:
- JDBC даёт полный контроль, но требует больше кода
- JPA повышает продуктивность, скрывая сложности
- Для сложных запросов иногда комбинируют оба подхода
- Выбор зависит от проекта: JPA для бизнес-приложений, JDBC для высоконагруженных систем
Совет: Современные проекты часто используют Spring Data JPA, который ещё больше упрощает работу с JPA.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2🔥2
Please open Telegram to view this post
VIEW IN TELEGRAM
😁4
Ответ -
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3👍2
Тернист и извилист путь Java-платформы к правильному способу записи строчек в лог-файлы. История logging в Java довольно познавательна в плане изучения особенностей Open Source, в том числе его взаимодействия с корпорациями и единичными программистами.
🔗 Ссылка на статью
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2
Ответ -
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3
На сегодняшний день sonarqube - один из самый известный способ автоматического анализа кода и его ревью. В данной статье показан процесс настройки sonarqube для вашего проекта.
🔗 Ссылка на статью
Please open Telegram to view this post
VIEW IN TELEGRAM
👍1
Roadmap "Как стать java разработчиком".
Карта показывает необходимые навыки для изучения
🔗 Ссылка
👩💻 Java Developer | Backend |#⃣ #обучение #java
Карта показывает необходимые навыки для изучения
🔗 Ссылка
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2❤1