Для простых запросов.
Для параметризованных и повторяемых запросов.
Для вызова хранимых процедур.
// Statement
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
// PreparedStatement
PreparedStatement pstmt = connection.prepareStatement("SELECT * FROM employees WHERE id = ?");
pstmt.setInt(1, 1);
ResultSet rs = pstmt.executeQuery();
// CallableStatement
CallableStatement cstmt = connection.prepareCall("{call myStoredProc(?)}");
cstmt.setInt(1, 1);
ResultSet rs = cstmt.executeQuery();
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍5❤1
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥25👍14❤1
Connection connection = DriverManager.getConnection(url, username, password);
Statement:
Statement stmt = connection.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM employees");
PreparedStatement
PreparedStatement pstmt = connection.prepareStatement("SELECT * FROM employees WHERE id = ?");
pstmt.setInt(1, 1);
ResultSet rs = pstmt.executeQuery();
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
double salary = rs.getDouble("salary");
System.out.println("ID: " + id + ", Name: " + name + ", Salary: " + salary);
}rs.close();
stmt.close(); // или pstmt.close();
connection.close();
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍11❤1
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🤔7
Для вызова хранимой процедуры в JDBC используется интерфейс
CallableStatement.Connection connection = DriverManager.getConnection(url, username, password);
CallableStatementCallableStatement cstmt = connection.prepareCall("{call myStoredProc(?)}");cstmt.setInt(1, 1); // Установка значения первого параметра
ResultSet rs = cstmt.executeQuery();
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
System.out.println("ID: " + id + ", Name: " + name);
}rs.close();
cstmt.close();
connection.close();
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.CallableStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class CallStoredProcExample {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/mydatabase";
String username = "myusername";
String password = "mypassword";
try {
Connection connection = DriverManager.getConnection(url, username, password);
// Вызов хранимой процедуры
CallableStatement cstmt = connection.prepareCall("{call myStoredProc(?)}");
cstmt.setInt(1, 1);
// Выполнение и обработка результатов
ResultSet rs = cstmt.executeQuery();
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
System.out.println("ID: " + id + ", Name: " + name);
}
// Закрытие ресурсов
rs.close();
cstmt.close();
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍31🔥6
Закрытие соединения с базой данных и связанных ресурсов (таких как
ResultSet и Statement) важно для освобождения ресурсов и предотвращения утечек памяти.ResultSetinterface IRepository {
doSomething(): void;
}
class Repository implements IRepository {
doSomething() {
console.log("Doing something...");
}
}
class Service {
private repository: IRepository;
constructor(repository: IRepository) {
this.repository = repository;
}
performAction() {
this.repository.doSomething();
}
}
const repository = new Repository();
const service = new Service(repository);
service.performAction();Statement или PreparedStatementif (stmt != null) {
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}Connectionif (connection != null) {
try {
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class CloseConnectionExample {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/mydatabase";
String username = "myusername";
String password = "mypassword";
Connection connection = null;
PreparedStatement pstmt = null;
ResultSet rs = null;
try {
// Установка соединения с базой данных
connection = DriverManager.getConnection(url, username, password);
// Создание PreparedStatement и выполнение запроса
String sql = "SELECT * FROM employees WHERE department = ?";
pstmt = connection.prepareStatement(sql);
pstmt.setString(1, "HR");
rs = pstmt.executeQuery();
// Обработка результатов
while (rs.next()) {
int id = rs.getInt("id");
String name = rs.getString("name");
double salary = rs.getDouble("salary");
System.out.println("ID: " + id + ", Name: " + name + ", Salary: " + salary);
}
} catch (SQLException e) {
e.printStackTrace();
} finally {
// Закрытие ресурсов
if (rs != null) {
try {
rs.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (pstmt != null) {
try {
pstmt.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
if (connection != null) {
try {
connection.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
}
}
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🤯1
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥18👍3❤1🤯1
Чтобы написанная на Java программа заработала, необходимо выполнить несколько шагов, начиная с написания кода и заканчивая его запуском.
Напишите Java-код в текстовом редакторе или интегрированной среде разработки (IDE), такой как IntelliJ IDEA, Eclipse или NetBeans.
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello, World!");
}
}Убедитесь, что на вашем компьютере установлен JDK (Java Development Kit). JDK включает в себя компилятор (javac) и виртуальную машину Java (JVM). Скачайте и установите последнюю версию JDK с сайта Oracle или OpenJDK.
Компилируйте Java-код в байт-код, который будет выполняться на JVM. Для этого используйте команду
javac. После компиляции появится файл HelloWorld.class, содержащий байт-код.javac HelloWorld.java
Запустите скомпилированный байт-код с помощью виртуальной машины Java (JVM), используя команду
java. java HelloWorld
Вывод должен быть:
Hello, World!
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13😁4🎉4
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥13👍7
Использование интерфейсов и абстрактных классов позволяет определить контракт (набор методов), который класс должен реализовать. Это позволяет легко менять реализацию, не изменяя код, который использует эти интерфейсы.
// Интерфейс
public interface PaymentProcessor {
void processPayment(double amount);
}
// Одна реализация
public class CreditCardPaymentProcessor implements PaymentProcessor {
@Override
public void processPayment(double amount) {
System.out.println("Processing credit card payment of " + amount);
}
}
// Другая реализация
public class PayPalPaymentProcessor implements PaymentProcessor {
@Override
public void processPayment(double amount) {
System.out.println("Processing PayPal payment of " + amount);
}
}
Этот принцип подразумевает, что высокоуровневые модули не должны зависеть от низкоуровневых модулей. Оба должны зависеть от абстракций. Это достигается с помощью внедрения зависимостей (Dependency Injection, DI).
public class PaymentService {
private PaymentProcessor paymentProcessor;
// Конструктор принимает интерфейс, а не конкретную реализацию
public PaymentService(PaymentProcessor paymentProcessor) {
this.paymentProcessor = paymentProcessor;
}
public void makePayment(double amount) {
paymentProcessor.processPayment(amount);
}
}
// Использование разных реализаций
PaymentService service = new PaymentService(new CreditCardPaymentProcessor());
service.makePayment(100.0);
service = new PaymentService(new PayPalPaymentProcessor());
service.makePayment(200.0);Паттерн Стратегия позволяет определять семейство алгоритмов, инкапсулировать их и делать их взаимозаменяемыми. Это позволяет алгоритмам изменяться независимо от клиентов, которые их используют.
// Интерфейс стратегии
public interface CompressionStrategy {
void compress(String data);
}
// Конкретная стратегия
public class ZipCompressionStrategy implements CompressionStrategy {
@Override
public void compress(String data) {
System.out.println("Compressing using ZIP");
}
}
// Другая стратегия
public class RarCompressionStrategy implements CompressionStrategy {
@Override
public void compress(String data) {
System.out.println("Compressing using RAR");
}
}
// Контекст, использующий стратегию
public class CompressionContext {
private CompressionStrategy strategy;
public void setStrategy(CompressionStrategy strategy) {
this.strategy = strategy;
}
public void compress(String data) {
strategy.compress(data);
}
}
// Использование
CompressionContext context = new CompressionContext();
context.setStrategy(new ZipCompressionStrategy());
context.compress("MyData");
context.setStrategy(new RarCompressionStrategy());
context.compress("MyData");
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥16
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14
JSP страница переводится в сервлетный Java-код. JSP контейнер анализирует содержимое JSP страницы и создает соответствующий сервлетный исходный код (.java файл).
Сервлетный исходный код компилируется в байт-код, создавая .class файл (сервлет). Этот этап аналогичен компиляции обычного Java-кода.
Скомпилированный класс сервлета загружается в память. Контейнер загружает класс сервлета, чтобы он мог быть выполнен.
Контейнер вызывает метод
jspInit(). Этот метод вызывается один раз при первом создании сервлета или при перезапуске сервера и предназначен для выполнения инициализационных задач (например, настройка ресурсов).Для каждого HTTP-запроса вызывается метод
jspService(). Этот метод обрабатывает входящий запрос и генерирует соответствующий ответ. Основная работа по генерации динамического содержимого происходит на этом этапе.Когда JSP страница выводится из эксплуатации (например, при остановке сервера), контейнер вызывает метод
jspDestroy(). Этот метод используется для освобождения ресурсов (например, закрытие соединений с базой данных).Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🤔1
Жизненный цикл JSP страницы включает несколько ключевых методов, которые выполняются на различных этапах от инициализации до завершения.
Этот метод вызывается контейнером сервлетов один раз, когда JSP страница загружается впервые или когда она перезагружается. Инициализация ресурсов, таких как подключение к базе данных, настройка начальных параметров и другие задачи подготовки.
public void jspInit() {
// Инициализация ресурсов
System.out.println("jspInit() вызван");
}Этот метод вызывается контейнером для обработки каждого запроса, поступающего к JSP странице. Метод обрабатывает HTTP-запросы и генерирует ответы. Основная логика для обработки запроса и генерации динамического HTML содержимого.
public void _jspService(HttpServletRequest request, HttpServletResponse response) {
// Обработка запроса
response.getWriter().println("Обработка запроса в _jspService()");
}Этот метод вызывается контейнером сервлетов перед тем, как JSP страница будет выгружена из памяти (например, при завершении работы сервера или при перезагрузке приложения). Очистка и освобождение ресурсов, таких как закрытие подключений к базе данных и другие задачи завершения.
public void jspDestroy() {
// Очистка ресурсов
System.out.println("jspDestroy() вызван");
}<%-- JSP Page --%>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<noscript>JSP Life Cycle Methods</noscript>
</head>
<body>
<h1>Hello, JSP!</h1>
<p>Current time: <%= new java.util.Date() %></p>
</body>
</html>
<%!
// Инициализация
public void jspInit() {
System.out.println("jspInit() вызван");
}
// Завершение
public void jspDestroy() {
System.out.println("jspDestroy() вызван");
}
%>
Вызывается один раз при загрузке JSP страницы.
Вызывается каждый раз при получении нового запроса к JSP странице.
Вызывается один раз перед выгрузкой JSP страницы из памяти.
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍16🔥6
Метод вызывается один раз при инициализации JSP страницы. Используется для выполнения инициализационных задач, таких как настройка ресурсов (например, подключение к базе данных).
public void jspInit() {
// Инициализация ресурсов
System.out.println("jspInit() вызван");
}Метод вызывается один раз перед выгрузкой JSP страницы из памяти. Используется для очистки ресурсов, таких как закрытие подключений к базе данных.
public void jspDestroy() {
// Очистка ресурсов
System.out.println("jspDestroy() вызван");
}Метод вызывается для обработки каждого запроса к JSP странице. Основная логика обработки запросов и генерации ответа. Этот метод автоматически генерируется контейнером сервлетов и не может быть переопределен вручную в JSP странице.
public void _jspService(HttpServletRequest request, HttpServletResponse response) {
// Обработка запроса
response.getWriter().println("Обработка запроса в _jspService()");
}<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<noscript>JSP Life Cycle Methods</noscript>
</head>
<body>
<h1>Hello, JSP!</h1>
<p>Current time: <%= new java.util.Date() %></p>
</body>
</html>
<%!
// Инициализация
public void jspInit() {
System.out.println("jspInit() вызван");
}
// Завершение
public void jspDestroy() {
System.out.println("jspDestroy() вызван");
}
%>
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍33🔥6👾2
Поместите JSP страницы в директорию
WEB-INF./WEB-INF/jsp/protected.jsp
Используйте сервлет для доступа к JSP страницам.
@WebServlet("/protectedPage")
public class ProtectedServlet extends HttpServlet {
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.getRequestDispatcher("/WEB-INF/jsp/protected.jsp").forward(request, response);
}
}Создайте фильтр для проверки условий доступа.
@WebFilter("/WEB-INF/*")
public class AuthenticationFilter implements Filter {
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
HttpServletRequest httpRequest = (HttpServletRequest) request;
HttpServletResponse httpResponse = (HttpServletResponse) response;
if (httpRequest.getSession().getAttribute("user") == null) {
httpResponse.sendRedirect(httpRequest.getContextPath() + "/login.jsp");
} else {
chain.doFilter(request, response);
}
}
}Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7
Ставь 👍 если знал ответ, 🔥 если нет
Забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍14🔥2
Неподвижный контент, который не изменяется при каждом запросе. Обычно это HTML, CSS, JavaScript, изображения и другие медиафайлы. HTML-теги, текст, ссылки и изображения, которые всегда одинаковы для каждого пользователя.
<!DOCTYPE html>
<html>
<head>
<noscript>Static Content Example</noscript>
</head>
<body>
<h1>Welcome to my website</h1>
<p>This is a static paragraph.</p>
</body>
</html>
Контент, который может изменяться при каждом запросе в зависимости от данных, входных данных пользователя или бизнес-логики. Это генерируется на сервере с использованием Java-кода. Результаты поиска, данные пользователя, время и дата, данные из базы данных.
<!DOCTYPE html>
<html>
<head>
<noscript>Dynamic Content Example</noscript>
</head>
<body>
<h1>Welcome to my website</h1>
<p>Current date and time: <%= new java.util.Date() %></p>
<p>Your IP address: <%= request.getRemoteAddr() %></p>
</body>
</html>
-Статическое содержимое
Не меняется при каждом запросе.
-Динамическое содержимое
Может изменяться в зависимости от условий и данных.
Статическое содержимое
Быстро загружается, так как не требует обработки на сервере.
Динамическое содержимое
Может быть медленнее, так как требует обработки и генерации контента на сервере.
-Статическое содержимое
Не использует серверные ресурсы для генерации.
Динамическое содержимое
-Использует серверные ресурсы для выполнения логики и генерации контента.
Статическое содержимое
-Основные страницы, справочные документы, статические изображения.
Динамическое содержимое
-Пользовательские профили, результаты поиска, данные из базы данных.
Ставь 👍 и забирай 📚 Базу знаний
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4❤3😁1